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(57) Abstract: Client software, enabling a client to run a network based application which uses structured data, in which the client 
software comprises: (a) a communication layer to send and receive messages over the network; (b) a database layer to store, and 
allow querying of, the structured data; (c) a rendering layer which generates, from the structured data in the database layer, data 
for a user interface; wherein the client software is self-contained to provide all of the communications, data storage and rendering 
resources needed to run the network based application on the client device. The 3 Layer System is fully integrated and therefore 
requires no additional client side code to be written. Normally, this level of self-containment on the client side does not exist, so 
that a developer wishing to deploy a network based application to a client device needs to write client side custom code for the user 
interface. 
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CUENT SOFTWARE ENABLING A CLIENT TO RUN A NETWORK BASED 
APPLICATION 

5 BACKGROUND TO THE INVENTION 

1. . Field of the invention 

This invention relates to client software enabling a client to run a network based application. 
10 It finds particular utility in enterprise computing. A network based application is any 
application in which data has to be sent to a client device over a network, such as a WAN 
like the internet or a LAN. It includes web applications, back end applications and web 
services. 

15 2. Description of the Prior Art 

Enterprise computing was originally conducted through large mainfirame computers. These 
mainframes gave the end-user very limited application functionality, displaying only text 
messages and requiring keyboard strokes for every command (for example, there was no 
20 mouse and none of the richness of toda/s desktop applications like drag and drop, graphing, 
sorting or personalized settings). Deployment costs were also very high due to the cost of 
hardware and the lack of skilled computer operators. 

The evolution to client/server-based computing provided much richer functionality. The 
25 graphical user interface (GUI) provided end-users a much simpler, more efficient method to 
interact with applications, but systems still proved expensive and difficult to maintain. In 
theory, applications would be deployed on tiie server centrally and distributed via the 
network to each of the clients. But business users had different needs of fiinctionality and 
therefore required different applications with unique configurations. Not only did some 
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information have to be personalized, but information also had to be retained on the desktop. 
This meant it was not possible to 'Svrite once and deploy many". The result was that the 
end-user got the desired rich functionality, but much of the code for the business logic for 
the applications was located on individual clients. IT Departments' budgets ballooned due to 
5 hig^ support costs and slow implementation times » Rolling out new applications - or even 
minor updates - required a unique installation for every PC that required access. 

The advent of the Intemet was supposed to change all this. The Internet provided an 
infrastructure that lent itself to the notion of zero-cost deployment with the promise of 
10 'Vrite once, mn anywhere". Such a model would significantly decrease the cost of deploying 
enterprise systems. With the Internet, back-end servers would run the application centrally, 
and all that users required to access the application was a browser. There would be no code 
specific to the application running on the user's client The potential this promised to large 
companies was unprecedented. 

15 

Despite the enormous potential, the initial technology (HTML) used for building and 
deploying the front-end of these new Intemet applications was never intended for anything 
more than displaying simple text As companies tried to deploy sophisticated business 
systems over the Internet, they soon realized that much of the desired functionality they 
20 wanted was not feasible. HTML based Web Applications did not have tme interactivity or 
access to data in real-time. Business users needed to interact with and manipulate the data, 
but mostiy what they saw was static page views. Certain solutions were designed to provide a 
more interactive user interface. However, they still used variations of HTML^ resulting in 
passive documents with numerous limitations. 

25 

Specifically, from a technical perspective these limitations resulted in: 

• Lack of functionality: No matter how sophisticated the back-end business logic, end- 
users lost the functionality they had come to expect from their familiar client/server-based 
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system. Latge online systems that were deployed severely lacked the rich functionality that 
companies demanded in their offline systems. While lots of money was spent on building 
these systems, to date they have clearly not replaced client/server systems. In fact; very few 
even augment the existing offline systems, and in retrospect proved to be very expensive IT 
5 exercises which fell short of their original promise. There have been early attempts at 
providing a richer user interface and a more robust connection between the back-end servers 
and the client by using JavaScript, DHTML, and various plug-ins. However, these solutions 
present expensive development cycles and ongoing maintenance, while introducing new 
security issues (see below), and applications that still fall short of the desired functionality. 

10 

• Load on back-end Servers: The HTML-based Web represents a very inefficient use of 
computing resources. Publishing HTML's required page by page structure means that as 
more people log on to a system, requests to the database and the application server put a 
strain on these servers. Companies needing to scale operations can buy more servers with 

15 more CPUs to handle the high load, but each additional processor not only costs a lot, but 
may also affect the license cost of all the various software packages mnning on the server. 

• Security Concerns: Companies are concerned that data pushed beyond corporate firewalls 
onto the Internet is open to unauthorized, third-party scrutiny. Additionally, there is concern 

20 that plug-ins downloaded from various Internet applications may contain viruses. Most 
software companies license their software on a per-CPU basis. As companies add more 
CPUs to their servers or add entirely new servers, tiie licensing fee for each piece of software 
increases by a multiple of how many new processors are added. 

25 • Cannot Easily Prototype New Features: Given the complexity of developing user 
interfaces that provide adequate functionality and the effort required to integrate such 
solutions to the back-end, companies typically do not prototype and roll out new features 
incrementally. Very often, further development of tiiese systems is an extensive project, 
which introduces the uncertainty of never being fiilly deployed and used. Because of the 
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effort required for each release, many companies shy away entirely from going forward on 
certain projects as opposed to rapidly developing incremental pieces to see what parts work. 

From a business manager's perspective, these limitations meant 

5 

• Inadequate Systems for Doing Business: Client/server-based systems were expensive, 
difficult to bxiild and deploy and not accessible outside of the enterprise. However, diey do 
provide the functionality needed to actually do business, whether for trading financial 
instruments, managing resources and accounts through ERP systems or selling and 

10 maintaining client relationships through SFA and CRM tools. A fiiaction of these capabilities 
are available over the Internet in certain systems, but are far from giving the functionality 
people require to be effective. 

• Slow Performance: Sites using HTML force users to dick and wait for a response while 
15 the back-end system processes the information and pushes a new page to the users. This can 

take a few seconds at best, or tens of seconds, even minutes, at worst Users of these systems 
simply abandon activities when they take too long or when connections entirely fail. 

• Expensive Development: Building and deploying enterprise-level systems over the 
20 Internet with sophisticated functionality requires a lot of custom coding with long and 

expensive development cycles. Most of this work cannot be leveraged for other systems and 
is a large, one-off expense that companies must absorb. 

• Expensive Maintenance: Complex Web systems contain thousands of lines of code on 
25 both the back-end (business logic) and the front-end (delivers the interface). The connection 

between the front-end and backend also contains thousands of lines of custom code which 
needs to be debugged and maintained. All changes to the code require programmers to 
manually write new code and test the functionality through staging before going to a live 
production site. 



wo 02/065286 



PCT/GB02/00578 



5 



• Expensive Bandwidth: In today's online systems, information is presented to users 
through entire Web pages, which are pushed out to users over the network. As information 
changes or transactions are completed, users can request new pages or submit pages back to 

5 the system. However, every time pages are sent across the network, companies pay for the 
bandwidth used. As online systems add users and these users start to do more activities 
online, they consume more and more bandwidth, and as a result costs increase quickly. 

• Mobile Access: As the reach of the Internet extends beyond the PC, enabling mobile 
10 access (i.e. PDAs, Cellular Phones) to business applications is becoming a standard business 

requirement Current solutions for wireless delivery require separate application re-writes 
(and expertise) for each device supported, 

• Hiring and Retraining expensive IT Staff: Integration of Web systems with existing 
15 offline systems and the maintenance of more sophisticated user interfaces for the Web using 

JavaScript and HTML typically requires armies of programmers, burdening the budget of 
every department, and many times putting the overall company's viability in jeopardy. 

As a result of these challenges experienced to date, companies still have limited confidence 
20 in deploying their systems through the Web. Re-creating the same feature-rich interfaces that 
existed on client/server-based desktop applications has proven futile for companies 
attempting to move their systems to the Internet Replicating the performance of desktop 
applications as well as standardizing the collaboration and interaction between disparate Web 
applications has been even more complex, expensive, and mostly elusive. The massive trade- 
25 off in end-user productivity, combined with security, scalability and performance concerns, 
has resulted in enterprises mnning client/server systems in parallel with Web-enabled 
systems, further deepening the cost of IT, and still not realizing most of the benefits the 
Internet promised. 
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Hence, even though millions of people are now using the Internet to look at documents 
from anywhere in the world, true interactivity to manipulate data is missing, and the 
evolution of the Web into a mainstream business and trading environment simply has not 
happened. 
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SUMMARY OF THE PRESENT INVENTION 

In a first aspect of the invention, there is provided: 

Client software, enabling a client to run a network based application which uses structured 
5 data, in which the client software comprises: 

(a) a communications layer to send and receive messages over the network; 

(b) a database layer to store, and allow querying of, the structured data; 

(c) a rendering layer which generates, firom the structured data in the database 
layer, data for a user interface; 

10 wherein the client software is self-contained to provide all of the communications, data 
storage and rendering resources needed to run the network based application on the client 
device. 

Prior art approaches to solving the problem of deploying network based applications to 
15 clients (e.g. interactive web based applications) suffer from the extensive problems identified 
in the preceding section. For example, they have consistently required programmers to write 
client based code: Internet Explorer™ from Microsoft Corp, Redmond, USA, includes an 
XML Document Object Model (DOM) - i.e. an XML database which will run on the client 
device. But a programmer wishing to deploy a web based application to a client running the 
20 Internet Explorer DOM needs to craft JavaScript or other 'code' to interpret data in the 
XML DOM and effect changes to a DHTML page in the browser. Alternatively, a 
programmer might use a tool to automatically generate and embed the 'code' into the 
DHTML page. In either case, the code is explicity required to generate the conversion from 
XML to user interface. No such client side software development is needed with the present 
25 invention because it is a self-contained and complete *3 Layer System* providing 
comprehensive commxmications/ database/renderer functions. 

The 3 Layer System is fully integrated and therefore requires no additional client side code 
to be written. As data {' Application Data*) changes in the Database Layer, it automatically 
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communicates with the Rendering Layer causing it to update the user interface appropriately. 
Similarly, any changes to the user interface caused by user interaction (eg pushing a button, 
turning a dial or entering in new information through a keyboard) can cause the Rendering 
Layer to notify the Database Layer of any changes that have taken place. 

5 

Changes to the Database layer caused by the Rendering Layer can automatically cause the 
Database Layer to contact the Communications Layer and can cause it in turn to send 
messages over a network that indicate modifications to the Application Data on the client 

10 This seamless, integrated and automatic interaction between tiiese layers in both directions 
can be done without the need for traditional programming methods and is inherent to core 
implementations of the invention. 

The result is that this invention enables the rapid creation and deployment of highly 
15 interactive, network aware applications whilst taking fiill advantage of the rich structure 
within the application's data, and without the need or expense of traditional programming 
approaches. 

Interaction between the client and tiie server is carried out at tiie Application Data level 
20 between tiie server and the Database Layer via the Communications Layer. The server need 
not even know of the existence of a Rendering Layer on tiie client Thus, the 3 Layer System 
serves to fiilly insulate the user interface of the client device from a server hosting ihe 
network based application. Normally, this level of self-containrnent on the client side does 
not exist, so that a developer wishing to deploy a network based application to a client device 
25 needs to write client side custom code for the user interface, as in the Internet Explorer 
example given above. Also, in the traditional example, the server will often know about the 
rendering process on the client, and in most cases will generate the combination of 
Application Data and rendering instructions needed to render the information on the user 
interface. 
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The client software needs some limited hooks into standard resources on the client, namely 
those necessary for it to control the user interface of the client device (e.g. a screen or a line 
of LEDS), or provide non-visual functions (the term 'rendering^ should not be construed as 
implying only visual rendering, but to controlling any kind of device interface). It needs 
5 hooks into standard resources to send and receive data over the network. In one 
implementation, the client software relies on a Java Virtual Machine for this, but it can 
equally be run natively on an operating system; because it is self-contained (i.e. contains it^s 
own communications manager, database and rendering SYSteTn)^ porting to run on different 
operating systems is straightforward. 

10 

By tightly integrating the major inftastructure components needed to support a Network 
Based Application, implementations of the invention will often be significantly smaller in 
size and more efficient than were the components to be independent. As a result, these 
implementations are suited to run on devices with limited memory and processing resources, 
15 and/ or be deployed automatically at mn-time over a network. 

In one implementation, the database layer holds, independently of the structured Application 
Data, 'Configuration Data' which defines how that data can be interacted witii firom within a 
user interface. Hence, this database is not just a record set (i.e. the product generated by a 

20 database), nor is it simple HTML, in which data and configuration data are not independent 
but are, conversely, inseparable. Independence leads to a key advantage: the rendering layer 
continuously combines the Configuration Data and the structured Application Data (or 
rather sub-sets of both) at display time; Configuration Data can therefore be changed 
asynchronously from any user interaction. This independence of the Application Data and 

25 the Configuration Data enables the server to which the networked client is connected, to 
interact separately for changes to the Application Data and Configuration Data, and in many 
cases restrict its communications with the client to changes to the Application Data alone. 
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In one implementation, the structured Application Data and the Configuration Data is 
provided by a server (usually, but not invariably, physically remote firom the client; a server 
on the same device as the client is a possibility: it could then be a closed system). Normally, 
the user interface of a network based application (e.g. a web based application) is defined by 
5 the client - i.e. the look and feel of the data and the data displayed at the client is defined by 
the client But in this implementation, it is the server which defines this user interface; both 
Application Data and Configuration Data on the client database layer can be updated in real 
time by the server. 

10 Changes and additions can be made to the Application Data through user interactions with 
the Rendering Layer as an individual change (e.g. pushing a button), or a collection of 
changes (e.g. filling in a form or setting a group of switches). 

Changes to the Application Data can be configured to apply locally (i.e. not cause an update 
15 via the Communications Layer to the server). This migjit be used to store temporary 
changes, (e.g. should the user wish to pre-fill in a form but not submit it until some other 
event has happened). 

When Application Data is added or modified at a client device (e.g. a new customer name is 
20 added to a list of customers), it is possible to enforce that the new name is displayed on the 
client device only once the server has processed a request from the client to add the new 
customer, has verified that the change is allowed and has sent updating data to the client. 
The updating of the user interface (e.g. to show the new name) can also be independent of 
the submission of the initial request firom the client to the server (to add the new customer). 
25 In this way, the user who initiated the change (e.g. entered the new customer name) receives 
rapid feedback on the validity of that addition or change, whilst the update (e.g. to show the 
new name) is sent firom the server to the client (and any other client devices which need to 
know of the change) when it is ready for the users to see the new information. Because that 
updating inform^-tion can be sent to all clients at the same time, this approach is particularly 
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useful in environments (e.g. real time price feeds for trading financial instruments) where all 
users need to receive updated data at the same time. Because the server can be made to 
automatically send out updated data to all clients in real time, and the rendering layer can 
continuously take this updated data and display it appropriately, the data displayed on the 
5 client is live'. 

The dient software is also generic in that it is configurable on demand to the configuration 
parameters applicable to any cUent device. In particular, the communications layer can use a 
broad range of different protocols and bearers; the rendering layer can render to multiple 
10 device types. All three layers are entirely independent of the kind of network based 
application the client software is interfacing with. 

Further, the database layer can provide an interactive, 'thick client'-like interface for the 
client device such that sub-sets of the structured data held on the database layer can be 

15 selected, displayed, manipulated, altered or supplemented with much lower latency than 
conventional web applications » (A 'thick dient^-like interface is a jfunctionally rich interface 
common to desktop applications that accepts user input via mouse and/or keyboard to drive 
functionality without recourse to a server and is capable of implementing process flow (e.g. 
opening new windows) and business logic (conditional behaviours dependent upon data 

20 values, validation). 

The structured data may be in a self-describing meta-language, such as XML. The network 
over which the client and server communicate may be a WAN such as the internet, but 
equally may be a LAN or indeed a network-^intemal to a single device. Although in the 
25 preferred implementation, the three layers (comms/database/renderer) are in effect a 
unitary, fully integrated system, it is also possible for one or more of the comms layer and 
renderer layers to be plug-in components to a browser, with the browser including the 
database layer. The layers need not be discrete and separate, but can be interwoven. Also, 
each layer csm interact directiy with either or both of the other two layers - e.g. the rendering 
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layer submits server calls directly to the communications layer; the communications layer can 
interact directly with the rendering layer - invoking actions/alerts. 

The client software may be permanently resident on the device (e.g. part of the PROM on a 
5 mobile telephone) or may be remotely deployable. An implementation which is remotely 
deployable is a Java applet version of the client software: this is described in the Detailed 
Description section. 

Prior art applets have generally been custom built for a particular application and would be 
10 impossible to reconfigure for any other application without significant modifications to their 
native code. 

Generic rendering applets do exist for presenting content (e.g. Macromedia's Shockwave™ 
and Flash™ Players, Adobe's PDF Viewer, postscript viewers, spreadsheets such as 

15 Microsoft Excel™, word processors such as Microsoft Word™, presentation tools such as 
Microsoft PowerPoint™ or even web browsers such as Netscape Navigator'''^ and 
Microsoft Internet Explorer***^ and though they may contain certain similar components to 
this invention, in each case, the loose coupling of these components means that user 
interactivity and live updates necessitate the cost of programming the interface using some 

20 form of scripting language (e.g. JavaScriptTM). In most cases, the content is created in a 
content creation tool (e.g. a word processor or drawing tool), but interactions have to be 
scripted separately in that tool or by other means. 

Another class of generic rendering applets (e.g. X-Windows clients, Citrix's MetaFrame™, 
25 Microsoft Terminal Server and AT&Ts VNC^m) are able to provide a rich and interactive 
interface to a user over a network, thougji in each case the rendering is controlled by a server 
that sends low-level display instructions to the client applet as needed (e.g. when a user types 
in some information, the server receives an event for each keypress and responds with 
instructions on what text, its location and font to draw on a screen). These applets require 
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that an application be programmed to run on the server. The server wiU in some cases (e.g. 
Citrix and Microsoft Terminal Server) automatically determine the commands to send to the 
user interface. In other cases (e.g. X-Windows), the server application has to be programmed 
with explicit instmctions for sending rendering information to the client 

5 

A further dass of applets are those created to work with relational, databases (e.g. Oracle 
SQL* Forms, Microsoft Access™^ Powersoft Powerbuilder™, Gupta SQL* Windows™^ 
Microsoft Visual Basic'^^^. In each case, though it is possible to build 'applications* that 
automatically enable some user viewing and interaction of data in the database, dynamically 

10 configurable and real-time rendering of the user interface requires some form of 
programming or scripting. For the most part, the database is held on the server, so 
interactions by the user that require complex queries (e.g. filtering) can often result in each 
client requesting new data from the server database thus increasing network traffic and 
server load. Furthermore, even in the case where the network communication, the database, 

15 and the rendering process are all on the client, they are typically loosely coupled and are 
deployed as independent components rather than as a single, tightly integrated architecture, 
and require separate configuration of each component on each client machine. 

In most cases, the above examples require device specific client-side installation and 
20 configuration. Implementations of the present invention can be deployed identically to 
disparate devices and configured entirely from the server, even to the extent of being 
deployed as needed at run time and disappearing when no longer needed. 

The thick client performance provided by-the-local applet-is derived in -part from distributing 
25 some of the data processing and run-time integration overhead (needed to operate web 
applications etc. rapidly) away from the originating web server/back end application etc. and 
sharing it instead between the generic applet on the client side (as defined above) and a new 
server side intermediary, which, as noted above, we refer to as a Tresentation Server'. (A 
Tresentation Server* is generally any kind of server that determines how data will be 
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displayed on a client device). Because the present invention relates principally to a client 
server architecture, it may be helpful to describe the entire client/server architecture at this 
point so that the 3 Layer System can be seen in context. (The 3 Layer System could in 
principle also be implemented in a peer to peer architecture, or in an entirely closed device, 
5 but the client server architecture is currently seen as the most commercially significant). 

More specifically, the database level of the 3 Layer System comprises data sent over a 
network from a remote Presentation Server which in tum receives that data (or super-sets of 
it) over a network from an originating source, which may be a web server, a back end 
10 application, a messages queue or a web service (or multiple sources of these types) able to 
generate structured data (e.g. XML or SQL format data direcdy (or indirectly through a 
generator). 

Hence, this client server architecture envisages a new approach which is neither entirely thick 
15 client, nor entirely client-server, nor entirely fully distributed, but blends aspects of each. It 
involves sending the structured data, which the client device needs to manipulate, once only 
from the originating source (web server etc.) to an intermediary Presentation Server. The 
Presentation Server then caches and sends this structured data, to the 3 Layer System on the 
client itself and subsequently keeps the database layer in the 3 Layer System automatically 
20 updated (or 'synchronised') with the originating source. The Presentation Server insulates the 
originating source from needing to know which clients need to be updated, what updates 
they need, how to communicate with clients, and the user interface at the clients. This 
overhead is instead handled by the Presentation Server; this approach allows an networked 
application developer to concentrate on application business logic development, rather than 
25 the front-end display/communications and synchronisation elements that traditionally take 
over 50% of developers' time. By pre-fabricating these complex functions and capabilities 
into a generic Presentation Server, networked application developers can produce finished 
applications far more quickly than previously. Scaling to large numbers of clients (1000s) is 
also possible, even for legacy back end systems which are limited to serving 10 or fewer 
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clients. This is because the back end system needs to supply information just once to the 
Presentation Server; the Presentation Server itself is fully scalable (e.g. multiple OPUS; 
multiple CPUs on multiple machines etc.) to serve the required numbers of client devices. 

5 There are two modes of operation that can be used together in the same configuration to 
handle updating. First, server based data updates - where all data interactions/functions are 
directed to the Presentation Server and then passed to the backend application. Updates are 
then picked up by and distributed to all relevant client connections. The result of the action 
(data changes) are then reflected in the local data and rendered. 

10 

Secondly, local data updates - data interactions are recorded locally in the database layer. 
Dependent upon the configuration, the data would then be sent to the PS/backend 
application. Any consequential changes which can be computed locally by the 3 Layer 
System are performed and the database layer updated, causing the display to be updated. 
15 Because the computation is entirely local, it is very rapid and gives the impression that the 
user is interacting with live data, i.e. data which directiy reflects values held at the originating 
source. The presence of the intermediary middleware Presentation Server is not discernible. 

With local data updates, changes to the local database can be also automatically sent by the 3 
20 Layer System to the Presentation Server, which in turn automatically updates the originating 
source. Any consequential changes to data at the originating source are then sent back up to 
the Presentation Server, which in turn works out which client devices need to know about 
this update and then sends them out to all client devices affected by the change. Careful 
design and deployment of web applications and 3 layer systems can maximise the extent of 
25 local computations (i.e. performed on the client device by the 3 layer system) and therefore 
minimise the frequency of interaction with the Presentation Server or originating source, 
which are typically co-located in a physically remote setting far from client devices and 
accessible over only over a WAN such as the internet. 
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In a second aspect of the invention, there is a networked application which, when invoked or 
run, causes client software as defined above to be run on a client device. 

In a third aspect of the invention, there is web server which hosts a web application which 
requires client software as defined above to be run on a client device. 

In a fourdi aspect of the invention, there is a client device when programmed with client 
software as defined above. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention will be described with reference to the accompanying drawings, in 
which: 

Figure 1 is a schematic of the main components of the AltioLive Client (ALQ; 

Figure 2 is a schematic showing the order of events, which occur when a client 
communication is initiated; 

Figure 3 is a schematic showing the chain of events, which occur when a user does 
something, which requires additional data; 

Figure 4 is a schematic of various aspects of the ALC configuration; 
Figure 5 is a schematic of a simple Synchronization Engine configuration; 
Figure 6 is a schematic of a complex Synchronization Engine configuration; 
Figure 7 is a schematic of the AltioLive Deployment Architecture; 

Figure 8 is a representation of a screen view. The initial data served by the Synchronization 
Engine is shown in this example; 

Figure 9 is a representation of a Service Function; 

Figure 10 is a representation of a screen view depicting the Datapool; 

Figure 11 is a representation of a screen view of a "NEW_SALE" Service Function; 
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Figure 12 is a representation of a screen view of a "NEW„BID" Service Function; 

Figure 13 is a representation of a "Select Product" list, including a GET_APPIMG image 
5 server command; 

Figure 14 is a schenoatic of the full system architecture of an Altiolive application; 

Figure 15 is a schematic of the interaction between the Synchronization Engine and the 
10 Application with emphasis on three main areas; the Data Service Function, Image Service 
Functions and Datapools; 

Figure 16 is a schematic of Altiolive in Dynamic Mode. In Dynamic mode it is necessary to 
change the HTML to reflect the connection to the Synchronization Engine; 

15 

Figure 17 is a schematic of the Logon process used by the AltioLive Demonstration 
applications. 
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DETAILED DESCRIPTION OF THE PREFERRED IMPLEMENTATION 

The invention will be described with reference to an implementation called AltioLive, from 
Altio Inc. of Boston, Mass., USA. This Detailed Description is organized as follows: 

5 

A. AltioLive - a Brief Overview of the Overall Architecture 

B. AltioLive Client — Overview 

C. AltioLive Presentation Server - Overview 

D. AltioLive Client - Details 

10 E. AltioLive Synchronisation Engine (SE) - Details 

F. Deploying AltioLive 

G. Security Aspects of AltioLive 

H. AltioLive — Benefits of using AltioLive 
L. Glossary 

15 

Appendix L "Getting Started with AltioLive" from Altio Lnc; Chapter 3 tided ' The 

AltioLive Presentation Server* 
Appendix LI "Lntegratimg AltioLive" from Altio Limited; Volume 4 Chapters 1- 5 of the 

AltioLive User Documentation. 

20 

A. AltioLive - a Brief Overview of the Overall Architecture 

AltioLive solves the technical challenges of streamlining development, deployment and 
25 maintenance of real-time interactive Lntemet/web applications. Updates to data items are 
received 'live' at a client device and can be transmitted concurrentiy and automatically to 
client devices to avoid users requesting updates and then having to wait for server responses. 
Access to tiie application through alternate devices (e.g. wireless access) presents the user 
witii their data automatically rendered for display and navigation on the device^ whether it is 
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a cell phone or a Personal Digital Assistant (PDA). For certain PDAs, AltioLive can be 
implemented directly (e.g. IPAQ). For cell phones, Web TV and lightweight PDAs, the 
application is provided via HTML or WML pages generated by a renderer engine in the 
Presentation Server. Thick client functionality is not provided on these devices. 

5 

Applications developed wildi AltioLive provide users the ability to move between windows 
inside the browser, scroll or sort through lists, resize columns and see details on selected 
items (mcluding charts and graphs). The windows can be minimized, maximized, moved 
around and resized, just like in a standard desktop application. Customizable toolbar buttons 
10 allow the user to pop-up additional windows to view further details such as lists, forms or 
graphs. Data entry is provided through the typical controls such as text boxes, checkbox, 
drop-down lists etc, with additional complex controls such as graphs, tree-views, date and 
color pickers. 

15 Since developing applications with AltioLive requires virtually no coding, development and 
ongoing maintenance efforts are reduced up to 75% while bandwidth and server-side 
processing decrease by a similar order of magnitude. 

In AltioLive, an Altio Presentation Server ('APS') deploys and intelligently manages real- 
20 time, interactive Internet or Web applications by serving appropriate XML data to client 
devices. The functions of the APS are (a) to receive and store XML data from the source of 
that data (e.g. web server, web service provider etc.); (b) to supply to each client device an 
appropriately configured 3 Layer System - in this instance a generic applet (as described 
above) - this generic applet handles client device display and communications functions; (c) 
25 configuration, initial data and supporting files (images and 'skins') and (d) to provide XML 
formatted data updates to the client in real-time and (e) to process client device requests to 
process updates and /or provide further information. 
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The APS therefore assumes responsibility for properly configuring the generic applet so lhat 
the database layer (an XML database layer in the case of AltioLive) on the client displays the 
correct data for a particular user, in the correct format and with window controls appropriate 
to that user, and in an optimal manner for the display capabilities of different client devices. 
5 It also assumes responsibility for all communications functions to/firom the client device by 
appropriately configuring the generic applet, which it sends to the client device. The 
communications functions enable data to be exchanged with any device type and OS (e.g. 
PC, Apple™, Unix^M^ Symbian™, Palm^M etc) and over any bearer/protocol. 

10 The updating function ensures that all client devices are up to date or synchronized. In 
AltioLive, this function is achieved using one or more clustered 'Synchronization Engines' 
(SE). A SE is a server-side software application, which runs on the Altio Presentation Server, 
and coordinates and controls the interaction between multiple clients, Web applications and 
server data sources over multiple communication protocol types, while still being 

15 configurable via industry standard XML, The SE allows for enterprise scale real-time data 
updates without the need for a client to use a browser 'refresh' button; live data 
synchronization across multiple users is possible. Static applications can therefore be 
transformed into dynamic ones and these applications can be extended to multiple devices in 
different formats, all from a centrally managed location. 

20 

In AltioLive, the generic applet is called the Altiolive Client; this applet enables live data to 
be displayed in fiiUy interactive windows inside a user's browser. Upon a request to the web 
server or other ultimate data source, by the client device, the AltioLive Client is deployed to 
the user's machine from the SE as a small Java- applet. The applet is generic and self- 
25 contained — i.e. no additional code is needed to make it suitable for a specific purpose. 
Instead, it interprets the configuration file sent from die SE to implement different views 
and behaviours so that it works for a specific web application/client device/bearer 
combination. 
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B. Altiolive Client — Overview 

The AltioLive client has three layers: 

5 (a) a generic communications functions layer (establishing and maintaining connections; re- 
connecting, updating etc.); 

(b) a generic rendering/graphics layer (generates appropriate screen responses to mouse 
drags and actions etc.) and 

(c) a database layer (stores applet configuration parameters and UI parameters like windows, 
10 window controls, data binding to these controls and event models; stores also the web 

application related data (a super-set of what is displayed at any time)). 

All three layers are necessary parts of the 3 Layer System, and each plays an important role in 
delivering the desired functionality/behavior. 

15 

B,l. The Communications Layer 

The communications layer provides a means to robustly send and receive messages between 
the network based application running on the client^ and the necessary supporting 
20 Presentation Server. 

Key features: 

Establish connection with Presentation Server to obtain interface configuration 
information (in a current implementation this is delivered as XML) 
25 - Establish occasional on-demand connection with the Presentation Server to obtain 

ad-hoc information as needed by the network based application (e.g. a response to a 
search query) 
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- Establish occasional on-demand connection with the Presentation Server to deliver 
new and/or updated network based application data to the Presentation Server (e.g. 
when a user submits a form), and await a response on success/ failure 

- Establish regular polling connections to receive network based application data to be 
presented in the interface 

- Establish and maintain a persistent connection to a Presentation Server if required 
for low-latency receipt of streaming data 

- Establish occasional connections with the Presentation Server to ensure server is 
alive (functioning) if needed when no streaming data has been received for a 
significant period. 

Interface to the Database Layer to deliver new and updated information from the 
Presentation Server 

Interface with Database Layer to receive messages to be sent to the Presentation 
Server (e.g. when tiie network based application data is changed) 

B.2 The Database Layer 

The Database Layer provides a means to hold and query network based application data and 
user interface configuration data as well as an interface to tiie Communications Layer and 
tiie Rendering Layer. 

Key Features: 

- In the generic case it receives digital information from the communications layer and 
efficientiy store it for later access on demand 

- Receive structured data from the Communications Layer that may later be queried 
using a query language to combine and/or extract specific subsets of data on demand 

- The structured data may be XML; XML querying approaches can be used to 
combine and/ or extract data subsets 

- The Database Layer can provide temporary cacheing of network based application 
data on behalf of the rendering layer; in order to reduce and/or minimize the need 
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for the 3 Layer System to communicate with the server in the course or running the 
network based application. 

- The Database Layer supports dynamic additions, modifications and deletions to the 
information it holds, tri^ered either by the Commmications Layer or the Rendering 
Layer. 

- The Database Layer responds on demand to requests for information firom the 
Rendering Layer. 

- The Database Layer may in response to a request firom the Rendering Layer, issue a 
request in turn to the Communications Layer to retrieve fiirther information from 
the Presentation Server (e.g. when the Rendering Layer has asked for data not yet 
present in the Database Layer) 

- The Database Layer may have a means to manage its si2e and may choose to expire 
and/or archive old or infirequently accessed information 

- The Database Layer works in conjunction with the Rendering Layer to automatically 
tri^r changes to the user interface to reflect the current state of the data in the 
Database Layer 

B.3 The Rendering Layer 

The Rendering Layer provides a means to (a) combine information describing an interface 
for a network based application with information to be rendered within that interface and (b) 
dynamically construct and manage the display of the application interface on the host client 
platform (e.g. a web browser or handheld device). 

- The Rendering Layer generates a user interface that reflects the state of the 
information in the Database Layer 

- Subject to the capabilities of the client device, the Rendering Layer can generate a 
dynamically updated user interface that continually reflects the latest state of the 
information in the Database Layer 

- The Rendering Layer may support interaction with an end user through inputs firom 
an external input device {e,g. a keyboard, button panel or mouse) 
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- The Rendering Layer may generate a network based application interface at the pixel 
level 

- The Rendering Layer is responsible for generating and managing user interface 
controls (e.g. text entry boxes, charts, scroll-bars) 

- The Rendering Layer may display information in a traditional desktop format using 
multiple overlapping views. 

- The Rendering Layer may support user interaction with the user interface such as 
drag & drop of information between views, entering data into a text box, pressing a 
button. 

- The Rendering Layer may support rendering of network based applications on 
devices and/or in a form other than pixels on a screen, (e.g. lines of text on a cell 
phone or LEDs on a domestic appliance) 

- The Rendering Layer may support interfaces to alternative rendering mechanisms 
independently of its own drawing capabilities (e.g. JavaScript calls and tri^ers to and 
from the Rendering I^yer) 

Other key features of the AltioLive Client are: 

• The generic applet provides a generic display capability by being able to download from 
the remote Presentation Server one or more of the following, each configured 
appropriately for the destination browser, device type and bearer: windows, controls on 
the windows, data binding to the controls and event models. The XML data is bound to 
the controls and event models, so that a web application developer need only define 
what data is to be associated with each window control; the applet then handles how 
data should be displayed when different events occur (e.g. if the data is a list of names, 
the applet handles how the name list is displayed if a 'sort by alphabetical order' control 
is selected). This 'View' definition can be made specific to each user - allowing different 
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users to be able to see or manipulate different data sub-sets and hence providing an 
access control mechanism. 

• The applet provides a 2er6-client footprint in that it is (a) installed on a client device only 
in response to the client device initiating or requesting a web application or web service 
and therefore does not need to be pre-loaded or installed and, (b) after the client device 
has ceased using the web application or web service, it may be removed entirely from the 
client device. 

• The small size of the applet allows it to be rapidly downloaded. Once the Java applet is 
running on the user's machine, it maintains a persistent connection with the Presentation 
Server. The Presentation Server will then 'push' or propagate new data to all parties that 
require it Only data, which has actually changed, is pushed across the network, reducing 
the bandwidth used, unlike HTML systems that send an entire page when only a single 
data point in the page alters. Another alternative to the persistent streamed connection 
is a polling connection, which makes regular requests for data changes. This uses a 
timestamp mechanism to ensure that only new updates for the individual client making 
the request are returned. 

• The XML database provided by the applet enables XML data from two or more 
different web applications, web services or data sources to be combined or manipulated 
in one or more windows running in a browser on the client device as though from a 
single source. 

• The generic applet can generate multiple windows in a browser window of the client 
device, with a user able to sort data, edit data, or scroll through data in each of the 
windows, without the need for there to be any client side software development 



wo 02/065286 



PCT/GB02/00578 



27 

• The generic applet allows XML to be cut and pasted into a clipboard or other form of 
temporary memory. Hence, a user can drag data (e.g. numerics, text or images) from one 
window generated by the XML database and drop it into another window — the 
appropriate changes ^including computations) resulting from pasting in the new data into 
the applicable field of the new window are generated and displayed. 

• The generic applet can generate multiple windows in a browser window of the client 
device, with each user able to define a personalised arrangement of windows and data to 
be displayed in each window, with the data to be displayed in each window capable of 
being obtained from several different web applications or web services. 

• XML data is associated with pre-defined controls by a developer and then at run time 
the generic applet automatically displays the data in conjunction with some or all of 
those controls. 

• The XML database can be accessed using XPath queries, in which standard XPath 
queries are enhanced with the following features: indexed retrieval; direct reference to 
elements and attributes identified by controls. 

• Session objects can allow the remote Presentation Server to provide to the XML 
database the applicable data and configuration parameters appropriate to the client 
device and the last state of the client device known to the remote Presentation Server . 
This prevents unauthorised access without a session object. Session objects are user 
specific, so that users can access a web application irrespective of client device being 
used. The PS also maintains the notion of a Connection, allowing a single session to 
support multiple connections (two browser windows for example) each running a 
different view/configuration. 
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C. Altiolive Presentation Server (APS) - Overview 

The AltioLive Presentation Server (APS) integrates with Web Applications to efficiently and 
securely distribute live XML data to users across the Internet through the range of Altio 
Clients. The APS has the following three functional aspects: 

■ Display - The APS provides a trusted architecture for the presentation of real-time 
interactive applications. Through a tiny, browser-based applet and XML^ 
configuration, Internet applications deliver a completely customisable, dynamic 
interface with desktop-style functionality (e.g. drag and drop, resizable windows, 
customisable screen colours, customisable fonts, full UI configurability according to 
user's role and preferences). 

■ Communications - The connection between the application (on the server) and the 
end-user (on the client) governing the form and method of conununication between 
the application (on the server) and display to the user (on the dient). The APS 
provides a persistent, secure connection between the application and clients, 
transmitting data via configurable HTTP/HTTPS polling or streaming access 
mechanisms. 

■ Data Synchronization - Managing data distribution across the user-base, providing all 
users with the latest data, in real time - from any device. 

The live data is displayed in interactive windows inside the users' browsers through the 
appropriate client: 

• AltioLive Client (ALC) — delivers a live, interactive, thick-client style user interface within 
the user's browser. 
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• Pervasive Client (APC) - delivers a page-oriented user-interface rendered for user access 
througjh simple devices such sis PDAs and mobiles. 

• Data Client (ADC) - delivers live, interactive data for presentation through a DHTML 
5 interface. 

Synchronization Engine (SE) 

The APS is implemented as one or more clustered Synchronization Engines (SE)s that are 
monitored and managed through the SE Admin Tool. 

10 

D. Altiolive Client (ALC) - Details 

The AltioLive Client is a computer user interface that radically enhances how information 
15 can be displayed and updated over Intemet technology. 

An ALC is composed of a number of components: 

■ An intemet chent nnachine; 

20 "A web browser supporting a Java virtual machine; 

■ A Java applet; 

■ An XML Desktop Database. 

These components are further described below and are shown in Figure L 

25 

The ALC 100 typically fits into a configuration that consists of a Web browser 103 in which 
the ALC runs as a small machine independent client applet. The web browser would be 
running on an Intemet Client 104 that would be connected to a web server 105 via the 
Intemet 102. The web server would be the gateway to the Intemet for a number of server 
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based web applications 106a and 106b etc. The Internet Client could be a personal 
computer running browser software, a Wireless Application Protocol (WAP) mobile phone, 
a Personal Information Manager (PIM), or other information-viewing device. For live 
connectivity these devices must support some form of network connection (e.g. by using the 
5 Java 1.1 Virtual Machine). The personal computer would typically be a workstation (e.g. PC 
compatible machine running a Windows™ operating system, Macintosh™ or Unix™ 
workstation); the browser software could for instance be Microsoft Internet Explorer™ 
version 5 (See www.Microsoft.com) or Netscape Navigator™ version 4 (See 
www.netscape.com). 

10 

In general the web server 105 would control the communication with the client using 
standard HTTP 109. Typically the ALC would use HTTP for the initial communication but 
could then switch to using altemative communication protocols, such as TCP/IP or UDP, 
which better suit the application. In this way the ALC and the SE set up their own 
15 communication link 110. 

One of the unique features of the ALC is that the Java Applet is small enough to be 
downloaded and configured on the browser each time the user starts a session with the 
application. This then gives rich client functionality without the need for add-ins and 
20 complex installation procedures. 

Once the ALC is running on the client it creates an XML Database (inside the ALC space) 
on the desktop which not only stores all the data immediately required by the client but also 
has all the configuration information on how the interface should look and what the user 
25 preferences are. 



ALC - SE Interaction 

The key to the uniqueness of the ALC is how it interacts with the SE. 
side layer that serves the ALC with the configuration, data and updates. 



The SE is a server- 



wo 02/065286 



PCT/GB02/00578 



31 

As can be seen in Figure 2, it is always the ALC that initiates the communication by 
requesting a page from tiie web server that contains the ALC applet 201 . 

The web server will pass the request on to tiie SE, which will return a page to the client 
5 containing the ALC applet The ALC is then initiated in the client browser and from then 
on establishes and maintains communications with the SE. To allow the user interfece to be 
personalised, the user must make themselves known to the system and will therefore be 
allocated a unique key that can be used to reference personal preferences. Upon request 
from the ALC the SE amalgamates XML from a number of sources to send back to the 
10 ALC 204. Typically tiie SE could get information from the following: 

■ General ALC configuration XML; 

■ User specific interface preferences; 

■ Web Application data, from potentially many applications. 

15 

The SE can be configured to retrieve this information in a number of different ways, 
including standard HTTP calls, SOAP, JDBC, Socket, or JMS. The ALC will use tiiis data to 
render a display to the user 205. The user can then interact with the data in a familiar 
desktop environment As the user interacts with the application the ALC may contact the 
20 SE for additional data or it may initiate an update of tiie data. 

When a user does something that requires additional data a chain of events takes place as 
described in Figure 3. The important step is that the SE can be configured to be an 
intelligent cache of web application data 304, thereby reducing the load on the web 
25 application itself. An example of this would be a news server. If the SE already has the 
requested news article then it doesn't need to interrogate the web application. The SE can 
also be configured to only return changed data therefore reducing the amount of data sent 
305. The SE uses a timestamp mechanism to ensure that a client connection only receives 
"new" data changes. 
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ALC Configuration 

The ALC is totally configured with the use of industry standard XML. There are a number 
of aspects to the configuration: 

5 

■ Interface definition 

■ Data Definition 

■ User Preference Definition 

■ Communications Definition 

10 

Referring to Figure 4, the interface definition 401 defines how the application will be 
rendered by the client in terms of windows, controls, images etc. This is initially defined for 
the application but then may be modified to take account of the user's specific configuration. 
The data configuration 402 defines the data to be served to the client. This is the XML 
15 definition of data that will be stored in the data section of the XML Desktop database. (The 
User Preferences 403, allow user specific requirements to be created and stored in the SE. 
These can then be used the next time the user logs on. 

The Communication Definition will define how the ALC should interface with the SE in 
20 terms of the underlying protocol. Typically this would be HTTP Streaming or Polling. 

E. AltioLive — Synchronisation Engine (SE) Details 

25 The Synchronisation Engine is a software application that can co-ordinate and control the 
interaction between multiple clients, multiple web applications or server data sources and 
multiple communication protocol types, while still being configurable via industry standard 
XML 
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Some unique features of the SE are: 

The ability to interface with existing web applications using a variety of protocols, 
including conventional HTTP, JDBQ SOAP, Socket, and JMS; 
In built scalability to support large numbers of simultaneous clients and to keep them 
synchronised with each other and the web application; 
In built fault tolerance through parallel clustering of SEs; 

The ability to plug together multiple SEs and allow them to discover each other and 
their data sources; 

The ability to decouple the refresh rates of the web applications and clients; 
The ability to communicate with a number of different client types, for example 
Internet browser, WAP phone. Personal Information Manager; 
Ability to pull together multiple web services; 
The ability to transport XML data elements to targeted destinations, 

An SE is composed of a number of components: 

■ A network server machine; 

■ A server operating system; 

20 "A communications protocol stack; 

■ AJava™ virtual machine; 

■ The SE Java servlet control programme. 

These components are ifurther described below: 

25 

The SE would be located on a network server machine. Typically there would be a CPU, 
random access memory, permanent disk storage, ports for communicating with other servers 
on the local network, a manual input device and a display unit. Once the server was set up it 



5 



10 
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would generally be administered remotely via the comms ports, in which case the keyboard 
and VDU might be removed. 

The server is designed to run an operating system that is stored on permanent disk and is 
5 loaded into memory at start-up. The operating system would typically be Windows Nl™ or 
Unix™ or Linux™, but could be any operating system that can support Java™ Servlets. To 
communicate over the local / wide area network the server would require a communications 
protocol stack such as TCP/IP. 

10 The software to control the SE would also be stored on permanent disk within the server 
and would also be loaded into memory as required. All the configuration information for 
the SE controlling software is stored as XML. 

Communications 

15 A key aspect of the SE is communications. The SE is able to communicate with back-end 
applications, with front-end clients and with other SEs. It can communicate at a number of 
different levels and in a nimiber of different modes. At the lowest level the SE controlling 
software will need to know the network protocol by which it needs to talk to each client and 
application. For communication to backend applications this could be HTTP, JMS, SOAP, 

20 Socket, or JDBC. Communication with the clients will typically be across the Internet and 
would therefore be over HTTP, but in some scenarios could be over TCP/IP or UDP. 
The SE will need to know the network address of each communications partner, for 
TCP/IP this would be the IP Address or the server name which this then translated into a 
TCP/IP address. 

25 

SE Configuration 

The SE would be configured from a number of XML configuration definitions. Referring to 
Figure 4, the server configuration 401 defines what data pools are going to be available and 
the definitions of the service functions required to interact with the web applications that are 
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enabled through the SE. The server configuration also defines the architecture of the SE in 
terms of clustering, security and communications. 

The data configuration 402 defines the data to be served to the client This is tihe XML 
5 definition of data that will be stored in each of the data pools. Each data pool is a 
transaction log, which tracks changes to the data set(s) held in the client. 

The application configuration 403 defines how the application will be rendered by the client 
in terms of forms, screen, images etc. This is initially defined for the application but then 
10 may be modified to take account of the users specific configuration. 

The application default 404 will store system defaults such as refiresh rates and other 
variables. These will be set at start up. 

Data Interaction 

15 Once communications are esta.blished between the SE, clients and web applications, the SE 
will need to transfer data between them. This can be by a number of methods: 

■ Push — This is where the SE propagates data to all'^parties that require it. This is used 
to keep the clients in sync with web application data changes. Web applications can 
also be set up to push data to the SE. 

20 ■ Pull - This is where the SE polls for the latest data, on a time basis or on user 

instigation. The client can also pull data from the SE. An example of a "Pull" is how 
changes to data on the web application are propagated back to the web client via the 
SE. Typically a web page is only refreshed when the user requests one and when it is 
refireshed all the data is transferred from the server even if it hasn't changed. The SE 

25 introduces a number of alternatives depending on the application requirements. The 

SE can be configured to check for changed data at different time intervals 404. If 
the SE detects a change 408 independently of a RE (Rendering Engine/Layer) 
request 402, then it can either cache the change or push it to all clients who currently 
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requite it Changes would only be able to be pushed to the RE if a suitable 
communications protocol was in place such as HTTP Streaming, TCP/IP or UDP. 

5 Simple Configuration 

The first embodiment of this invention, Synchronisation Engine Simple Configuration, is 
depicted in Figure 5. This figure shows the simplest configuration consisting of one SE 
server 504 which would be connected to a number of applications 507 and optionally the 
web server 508. It would also be connected to the Internet 503. 

10 

Complex Configuration 

Figure 6 demonstrates how multiple versions of the SE can be pieced together to form a 
scalable and fault tolerant network. This can be done without any code changes and with 

15 minimal configuration changes and the configuration tiiat is required is all via XML. The SE 
system can be deployed many times to produce a hugely scaleable and fault tolerant system. 
In this embodiment there are two main SEs 601 & 602, tiiese would act as dual redundant 
servers, providing a high degree of fault tolerance. Each SE would have independent links to 
the source applications 604. The SE invention embodies code tiiat will allow these servers 

20 to keep tiiemselves fijUy synchronised 603. 

This approach provides a large degree of scalability by allowing the SEs to be setup in a 
snowflake configuration. The two main SEs, 601 & 602 would act as the hub and would 
then be connected to otiier SEs 605 & 606 etc ratiier than directiy to clients. Each one of 
25 these satellite SEs could then be linked to a large number of clients. The SE invention 
incorporates the propagation logic required to service this complex snowflake configuration. 

More SEs could be setup in parallel to provide additional resilience and scalability. Also the 
snowflake configuration could be extended to have many layers thereby giving near infinite 
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scalability. Although in the above-described embodiment, the client was based on a web 
browser, it would be possible to have other types of user interface such as a Wireless 
Application Protocol (WAP) phone or a Personal Information Manager (PIM). The SE can 
also be split over many Central Processing Units (CPUs) within the same server or over 
5 many servers. 

F. Deploying AltioLive 

The generic applet must be configured so that the XML database layer on the client displays 
10 the correct data for a particular user, in the correct format and with window controls 
appropriate to that user, and in an optimal manner for the display capabilities of different 
client devices. The APS has responsibility for configuring the generic applet This is achieved 
via the XML Deployment Package (XDP). XDPs contain the definitions for the following 
AltioLive elements: 

15 

1. Service Functions - define the data (XML data & related Image data) available to users 
firom the Web Application and the mechanisms available to update the Web Application. 

2. Data Pools - define the mechanisms for live distribution of XML data updates to users, 

20 

3. AltioLive-Views — define the live interactive user-interface delivered through the AltioLive 
Client. There can be multiple views according to user roles. 

4. Pervasive- Views — define the page-rendered user interface delivered through the Pervasive 
25 Client. There can be multiple views according to user roles and/or device capability. 

5. Data-Views - define the data and access available through the Data Client for a DHTML 
user interface. 
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6. Common elements - icons, desktops styles etc. for use across views within the XDP. 
XDPs can be developed as self-contained entities. Typically a self-contained XDP is used 
where the views are tied to a specific Web Application e.g. a contract resource application 
could provide a requirement-view, a resourcing-view and a phone-based timesheet entry- 
5 view. Self-contained XDPs are also used in delivering third-party components (e.g. a Chat or 
e-mail component) lhat are effectively *plu^ed-in' to application-specific XDPs. XDPs can 
also make use of definitions from other XDPs to define tiieir views. Typically this is used 
where the views merge XML data from many applications into a specific role-based view 
(e.g. a salesman sees a cross-system-view combining sales tracking data, customer 
10 management data and credit control; the sales director sees a view combining aggregated 
sales data, personnel monitoring and campaign performance data) or to use elements of a 
third-party 

XDPs are developed within the AltioLive Development Edition (ADE) and tiien registered 
15 witii the APS using the SE Admin Tool. This distributes the XDP across all Synchronization 
Engines in a cluster to make it available to users. 

G, Security aspects of AltioLive 

20 AltioLive combines best-of-breed security technologies and practices to ensure a flexible, 
configurable and comprehensive security architecture for all applications. AltioLive is 
designed to integrate witiiin existing security frameworks. It takes advantage of existing 
session management and Secure Socket Layers and provides unique additional security 
features to offer a robust and highly secure envirorunent for all systems. 

25 

User Authentication 



In AltioLive, users do not directiy log-on to the APS. AltioLive intentionally reuses tiie 
session object created in the web server/application server in order to let you take advantage 
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of: 

■ existing authentication poKcies for the application; 

■ best practices in user authentication; 

5 ■ and the existing investment in technology infrastructure 

When the end-user accesses the application through a host Web page, this page downloads 
the appropriate Client from the same web server. The Client then contacts the APS, which 
uses the existing session object (on the server) to determine the specific View and XML data 
to be served to the user. Even if the URL of the host Web Page is known, the user cannot 
activate their connection with the APS unless they already have a valid session (including the 
necessary Altiolive specific variables) on the Web server. Using the existing session from 
the Web server also prevents users from having to re-authenticate as they cross boundaries 
in a distributed system. Altiolive allows users to authenticate only once, regardless of the 
machine on which the application is deployed. To control who can connect to the APS, 
AltioLive leverages existing application servers' ability to enforce mles that govern whether a 
connection should be established based on client IP access or protocol This allows 
companies to decide if "Clienf refers to AltioLive Client, AltioLive Pervasive Client, and 
the AltioLive Data Client 

Unique User Views and Data Pools 

Individual or groups of users can be assigned different views/windows, which can be 
populated by data specific to each group's or individual user's need. Groups and/or 
25 individually registered users can subscribe to different data pools in the APS. Users only see 
the data to which they subscribe. In this way, AltioLive prevents unauthorized users from 
seeing sensitive data as well as allowing for unique user experiences /views. Through the 
APS, system administrators can control which users see which data to ensure only the right 
data reaches the right users. For example, views could be configured for different roles in an 
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organization (i.e. Salesperson, Sales Manager, Credit Controller etc.) that provide access to a 
number of backend systems - each role would have a view that restricts what functions are 
available and deliver only data that is relevant to their role. Specifying individual access levels 
through the APS allows production systems to be up and running very quickly with minimal 
5 configuration and no coding. 

FirewaDs 

Use of standard HTTP and HTTPS connections between the Client and the APS makes the 
10 technology transparent to most firewalls and does not require any relaxation of existing 
security policies. In highly secure environments where connections are restricted, the 
Client/APS connection is specific and easily added to the allowable list of sites. An 
additional option for system administrators is to locate departmental slave (APS) servers that 
sit inside the firewall to support one or more users (who therefore no longer have to connect 
15 to the Internet). The slave server has a dedicated peer connection to its master APS that can 
be additionally secured according to company security policies . 

Connection Security 

20 Not only is it important that users are properly authorized and authenticated when accessing 
data from the APS, but also that this data cannot be viewed while in transit. To avoid 
eavesdropping on connections between any connections to the APS, AltioLive offers users a 
number of security features: 

25 Client to/from APS 

AltioLive includes support for a Secure Sockets Layer (SSL) and digital certificate 
implementation that provide authentication and privacy via encryption in distributed APS 
applications. The Client/APS connection takes advantage of current SSL technology 
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including 56 and 128 bit cipher strength connections. AltioLive is compatible with certificate 
authorities that support X.509v3 certificates. This means tiiat developers are firee to use the 
vast majority of certificate authorities available today. 

5 In secure operation, the APS requires a digital certificate to be able to prove its identity to 
Clients and other servers. When a Client contacts the APS using SSL, they first request die 
server's digital certificate to prove its identity. Once the Client receives the server certificate, 
identity is assured, and tiie Client and APS can confidentiy send data back and fortii across 
the network. For highly secure environments, many installations need to also authenticate 

10 the Clients accessing the APS. For tiiis reason, the APS SSL installation can be configured to 
also provide authentication for Clients and Web browser. This is called a two-way 
authentication and incorporates the same digital certificate verification process. The major 
difference for two-way authentication is that the digital certificates are located in botii the 
Client and the APSs. Once certificates have been exchanged and mutually verified, both the 

15 Client and the APS can trust the identity of the other. Furthermore, once mutual 
authentication has been set up, a private channel can be created between tiie two hosts 
consisting of encrypted data. Many systems will also require that the data which the Client 
receives from the APS and vice versa to be secure/encrypted. SSL allows both the APS and 
the Client to encrypt the data exchanged between them. Potential hackers acquiring the data 

20 in transit are therefore unable to understand it Streaming data connections are designed to 
make efficient use of secure connections to reduce server load as opposed to regenerating 
cipher keys for every request Use of compression techniques on the data stream fiirther 
enhances security while reducing the overhead of encryption on the overall system. Both the 
Client and the APS monitor connections to detect loss of connection. Clients' connections 

25 can be configured to either fail-over to another APS or require the user to re-establish their 
session through a login. 



APS to/from APS 
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The APS can be clustered for load balancing in master/slave relationships (as well as peer- 
balanced relationships). These connections are effectively point-to-point connections that 
can use HTTP, HTTPS or socket connections to secure the interface. If the APSs are 
distributed in geographically different areas (not in the same data center behind die same 
5 physical firewall, for example), the SSL protocol provides secure connections by allowing 
these APSs to connect over the Intemet and authenticate each other's identity and by 
encrypting the data between the APSs. For security above SSL^ hardware encryption can be 
used on the specific connection between servers. All APSs accessing the cluster must be pre- 
registered with compatible license keys, which prevent spoofing of any of the servers. 

10 

APS to/from backend Web Application 

The backend Web Application and the APS are usually in a closed and physically secured 
environment to prevent direct access to backend data from any outside client device. For 
15 implementations where the system connects across the Intemet to external Web Services, 
SSL and digital certificates provide the necessary authentication and data encryption to 
ensure that die Web Service is a proper entity and all data transmitted is only decrypted and 
viewed by the intended recipient. 

20 Reliable Data Delivery 

Data integrity and delivery is assured through a combination of HTTP generated exceptions 
and the APS/Client timestamp mechanism. All messages from the APS to the Client are 
time stamped and sent across the network using HTTP(S). Data from the APS is sent to the 
25 Client usmg HTTP. Should a loss of network connectivity or a temporary hardware failure 
cause any data not to be received by the Client, the built-in handshaking in the HTTP 
protocol generates an exception. Essentially, if a message cannot be sent firom the APS, the 
TCP/IP protocol generates an exception. This is generated in the server's Java Virtual 
Machine (JVM) and the exception is handled by the APS. The APS closes the connection 
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upon receiving an HTTP exception. The Client will automatically reestablish the connection 
with the APS (the reconnection strategy is configured through Altiolive Tools). When the 
connection is re-established, the Client requests all updates since the last timestamp that it 
successfully received, guaranteeing delivery of all messages in the correct sequence. For 
5 streaming data to the browser, the Client is just listening for data updates. In the case where 
it does not receive any updates or a probe message in a configured interval, it will start its re- 
connection process to the APS. In the meantime, the APS will generate an exception when 
the probe message cannot be sent. 

10 Transaction Authentication 

To prevent an unauthorized user submitting a transaction it is common to use forms of 
transaction authentication. This takes the form of access security/signature software on the 
client (sometimes even coupled to physical security - e.g. card swipe, challenge/response 
15 devices etc.) can add a security signature to any transaction. The Altiolive Client can be 
configured to call-out to such applications before submitting transactions to the server to 
either append the signature or encrypt the whole transaction. 

Use of shared workstations 

20 

Unlike many solutions, the CKent does not store any information locally on the workstation 
(configuration, data or even images). This means that the user can safely access their 
application firom shared/networked platforms without worrying that their data is accessible 
by others when they have logged-off. This is a key issue in the-access-anywhere features of 
25 Altio's technology. Standard session time-outs can be used on the server to time-out inactive 
sessions. The Client can also be configured to disconnect on logout and/ or moving from the 
host page to prevent someone using the Back/Forward fijnctions of the browser to 
reactivate the application (if it hasn't already timed-out). 
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Data Available to the User 

The data available within the XML Desktop and visible to the user is configured at design 
time and enforced by the APS. Users cannot configure their Client to access additional data 
5 not presented to their specific View. 

Protection for the User 

For the end-user, the Client is implemented within the standard Java 1.1 Security model. 
10 Altiolive Clients therefore do not have access to local data or services on the end-user^s 
system and developers cannot undertake bespoke development to override the functionality 
of the Client As an option, the Client can be 'signed' to give end-users additional comfort 
that the software can be trusted for use on the specific application. 

15 A Complete Security Architecture 

In addition to all of AltioLive's security features, companies must also ensure that they 
secure the general environment in which Altiolive is deployed. Such precautions include: 

20 • Securing the operating system: No security hole in the DNS, sendmail or any other 
potential entry points. 

• Securing File System: No general access to sensitive configuration information 
25 • Securing Network: Use of firewalls and VPN 

• Securing Physical Environment of the Server (s): Only authorized personnel have physical 
access to system 
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• Separating Development and Production Systems 

• No Source Code Available on Production System 

5 The combination of real desktop-like functionality in online systems tiiat users can access 
from anywhere, and the Internet becoming a proven and reliable medium for mission-critical 
communication is now driving companies to rapidly build new systems online as well as 
migrate existing systems to pure Internet Protocol-based applications using software 
platforms like AltioLive. Companies deploying IP-based applications must take special care 

10 that implementations are done in a secure and highly reliable environment to protect the 
substantial capital commitment required to build or to migrate any application online. 
AltioLive is designed to take advantage of existing security frameworks, such as session 
management, user authentication and Secure Socket Layers, reliable data delivery and 
transaction autiientication, and it provides additional unique built-in security functionality to 

15 offer the most robust and highly secure environments for developers and end-users at a 
fraction of tiie cost and time of alternative techniques. 

H. Benefits of using AltioLive 

20 With its XML-based architecture, AltioLive eliminates all tiie challenges posed by HTML, 
JavaScript and Dynamic HTML in the development of Internet applications. 

Specifically, AltioLive provides companies tiie following benefits: 

25 • Increased User Functionality: AltioLive provides a client/server-like environment 
directiy inside the browser, giving users the same power as they have in traditional offline 
client/server-based systems. With AltioLive users have all the data they need at their 
fingertips in real-time, allowing the functionality in tiie system to be richly interactive. 
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Graphs, drag-and drop, sorting, resizing and dynamically changing data are all available to 
users right inside the browser. 

• Enable Data delivery Across Devices: AltioLive allows end-users to access Web 
5 applications from any Internet enabled mobile device (including Palm, WinCE, WAP 

phones, and Web TV) - freeing them from the traditional PC-centric Internet experience. 
AltioLive applications can be deployed almost anywhere as they are based on pure XML and 
can be 'tuned* to meet people's various needs. 

10 • Savings on System Development: Using the AltioLive Designer tool, developers drag 
and drop lists, graphs, buttons, images, and design windows with the use of their mouse. 
There is no coding required to develop the front-end, and only minimal coding for the 
connection between the front-end and the back-end. This frees up precious programming 
resources to focus on building business logic rather than tedious and error-prone HTML. 

15 AltioLive significantly shortens development cycles, to enable faster time-to-market with 
considerable cost savings. Companies using AltioLive for large development projects have 
seen as much as 90% time and cost savings, equivalent to more than a million dollars in 
upfront cost. 

20 • Savings on System Maintenance: Since there is no code to be written for the front-end 
by the developers, AltioLive eliminates the chance of bugs through human error. Changes to 
the front-end can be implemented immediately using the Altiolive Designer tool. 
Connections from the client to back-end servers are also handled by AltioLive and while 
some of the integration requires actual code from developers, most of the tasks are 

25 automated by AltioLive. AltioLive reduces bugs and eliminates the need to have significant 
IT resources or consultants on hand whenever changes have to be implemented. 

• Savings on Bandwidth: AltioLive pushes data across the network only when the data 
actually changes. Even then, it only sends across the data that needs to be updated, not entire 
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pages, tables, graphs or windows. Consequently, AltioLhre-based systems substantially 
reduce the bandwidth used, saving companies substantial money on their bandwidth charges. 

• Fast Performance: Altiolive-based systems deliver the initial data set in compressed form 
5 to the client. Users immediately see any updates to the data as it changes from the back-end 

as well as when they make any modifications themselves through the client Most of the data 
will initially not travel over any network to a database for processing, but instead reside on 
the client available to the user. The proximity of the data to the user gives faster 
performance than most client/server-based systems; it performs like a thick client. 

10 

• Ability to Prototype New Features: With AltioLive it is easy to develop and prototype 
new features and make incremental changes. There is no coding involved when using the 
AltioLive Designer tool with XML-based Web services. The user interface, the logic betw^een 
the different windows and the connection to the back-end servers can be configured by the 

15 business person who will actually be using the system. 

• Customized and role-based views: Multiple views can be easily created for an 
application (e.g. basic vs. advanced or manager vs. employee) and be automatically 
distributed by individual or role. 

20 

• White Label Applications: The look and feel of an AltioLive application is determined by 
'skins' that allow very fine control (at the pixel level) of how applications look in the screen. 
The AltioLive Designer tool can tailor applications for a number of customers (i.e. 
incorporate their logos, borders etc.) to provide users with a uniquely branded experience. 

25 

• Secure Systems from Hackers: AltioLive provides secure communication through 
standard SSL (Secure Sockets Layer) and HTTPS with the Web server or application server 
doing the encryption and decryption in the server, and the browser doing the same on the 
client side. Additionally, the AltioLive applet mns in a carefiiUy protected 'sand box' 
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environment on the browser, preventing any ability to read/write to the hard disk drive on 
the computer. Altiolive-based applications can be used from public locations, such as net 
cafes, libraries etc. because it is as harmless as a plain HTML page and leaves no data cached 
behind. 

5 

• Less Load/Stress on Back-end Servers: Changes to data in the database are pushed out 
to the client in real-time, but only when changes occur and only the changed data is updated 
(not the whole window). This eliminates the need for users to constantly refresh the screen 
and make calls to the database on the back-end, which today causes heavy load when 

10 numerous users access the system. As users modify the data and submit new data back to the 
database, system administrators use the AltioLive Application Manager to configure how 
often this data is sent back to the database. This effectively allows system administrators to 
tune the system for optimal performance. Companies using AltioLive have reduced server 
load by as much as 90%. Since AltioLive decreases the stress on the back-end servers, 

15 implementations require less servers, or at least less CPU-intensive servers, which reduces 
hardware costs by thousands of dollars. Additionally, as most software Licenses are based on 
hardware CPUs, significant savings come from reduced software License fees. With certain 
enterprise software License fees approaching $75-100,000 per CPU, a reduction of even one 
or two CPUs could save a lot of money. 

20 

• Ability to Implement Changes Quickljr: AltioLive allows companies to instantly make 
changes, small or large, with virtually no coding on the client and only limited coding on the 
connection from the client to the server. This ability allows companies to adjust their 
systems on demand, rather than leave them with less than adequate ftinctionality as business 

25 requirements change. 



wo 02/065286 



PCT/GB02/00578 



49 

I. Glossary 

Altio Presentation Server (APS) - The operational platform for delivering live XML data to 
users through the Altio clients. 

5 

Altiolive Client (ALQ - Client that delivers a windows style live interface within a browser. 

AltioLive Pervasive Client (APQ - Multi-device client that renders onto devices such as 
WAP, Web TV, PDAs. 

10 

AltioLive Data Client (ADQ - Data-only client (i.e, no presentation) for use with dynamic 
HTML user interfaces. 

A ^client device' is any device which can be controlled over a network and has some means 
15 by which a human can view and/or interact with it It could be as simple as a network 
controllable light bulb and switch or more complex, such as screen & keyboard based 
personal computers. Software on the client device can be embedded or installed onto the 
device or delivered on demand to the device over a network. 

20 A 'data source' is any source of data potentially relevant to a network based application and 
includes basic data feeds (e.g. news headlines, equity quotes, sensor measurements) and more 
complex enterprise applications (e.g. Client Relationship Management, Human Resources, 
Enterprise Resource Planning and Accounting systems). Any ^ata source' can also be 
mdependently or simultaneously a 'data receiver' and accept structured data and commands 

25 from the presentation server. 

Domain Name System (DNS) - The Domain Name System (DNS) is an Internet directory 
service. DNS is used to translate between domain names and IP addresses, and to control 
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Internet email delivery. Most Internet services rely on DNS to work. If DNS fails, web sites 
cannot be located and email delivery stalls. 

HTTP Hyper Text Transport Protocol - A request-response type protocol that specifies that 
5 a client will open a connection to a server then send a request using a very specific format. 

HTTPS Secure Hyper Text Transport Protocol - A request response type protocol with 
encrypted data using Secure Socket Layer (SSL) 

10 Java Virtual Machine (JVM) - A self-contained operating environment that behaves as if it is 
a separate computer. For example, Java applets run in a Java Virtual Machine (VM) that has 
no access to the host operating system. 

A network based application is any application that can run over a physical or virtual 
15 network and where the client device is generally independent of the data source. A 
'networked based application' includes configurations where the network is virtual (e.g. both 
the 'presentation server' and the "client device" are on tiie same physical machine), or where 
the 'network' is established on occasion (e.g., as would be the case for many synchronizable 
handheld devices). 

20 

SE Admin Tool - An in-browser tool to administer and monitor Synchronization Engines. 

Synchronization Engine (SE) - The server-side component that integrates AltioLive with 
Web Applications and delivers live XML data. View what a user sees and interacts with in 
25 AltioLive-based applications - i.e. their interface to the application. 



Virtual Private Network (VPN) - A VPN is a private connection between two computers to 
transport private data over a public network like the Internet. A VPN offers encryption. 
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tunneling, authentication and access control effectively preventing data being intercepted in 
transit 
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Appendix 1 

"Getting Started with Altiolive" from Altio Inc.; Chapter 3 titled * The AltioUve 
Presentation Server' 

5 

In this chapter we will look at the Altiolive architecture and learn more about how the ROS 
demonstration application was created. 

Altiolive applications are deployed through the AltioLive Presentation Server (APS). This 
10 integrates with a back-end application (that could be supporting an existing HTML interface) 
and also supports the Altiolive Client In Figure 7 one can see tiie comparison between 
traditional HTML applications and AltioLive's technology. The deployment architecture has 
a number of key components: 

15 AltioLive Client - a small footprint Java applet that nans within browsers supporting a Java 
Virtual Machine (vl.l and above) — i.e. Microsoft Internet Explorer 4 or better; Netscape 
Navigator 4 or better. 

Synchronization Engine - Java servlets that maintain the communication between one or 
20 more back-end applications (through Service Functions) and die AltioLive Client. The Java 
servlets operate in a Java 1.3 servlet environment, and support JSDK 2.0 to allow for 
mstallation on common Application Servers. 

SE Admin - a browser-based tool used to configure and monitor one or more clustered 
25 Synchronization Engines. 

Configuration - XML files and images that configure the application interface presented in 
the AltioLive Client, XML files to configure tiie Synchronization Engine. 
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In Operation 

The end-user logs on to the site and accesses an HTML page (called the host page). This 
reserves space for the Altio Desktop on the page, and references a small footprint Java 
5 applet (the Altiolive Client). 

The Altiolive Client requests the Synchronization Engine to serve its View - an XML 
definition of the look, feel and operation of the user-interface. If the Synchronization 
Engine is not already running, it will read the server configuration file {aMoserver^xml) to 
initialize itself. 

10 Usmg session . parameters, lhe Synchronization Engine determines which AltioLive 
application and View the user is trying to access. It creates the xml definition of the View by 
combining the View definition file {appview^xml) with any retained preferences (e.g. window 
positions) from the user's last session. If the View refers to system images (e.g. skins, 
buttons etc) then these are also served to the client so that it can render the interface to the 

15 user. 

Note that the Sync Engine cannot initialize the back-end application; it assumes that any 
back-end application is already mtming. 

Service Functions and Data Pools 

20 

While requesting the View, the AltioLive Client also requests the initial data to populate die 
client-side XML Desktop. At this stage the Synchronization Engine loads die application 
configuration file {alHoapp.:>^t) to create the service functions and data pools required to 
serve data to the View. Using the View's initial data definition file (^/>-«f'e«^_data.xml) the 
25 XML data is requested firom the back-end application (via Service Functions) and served to 
the client. 

Service Functions can use either an HTTP connection, or be implemented using Java 
Messaging Service (JMS). 
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As part of its Application Configuration, the Client requests the Application Images (i.e. 
backgrounds, button images, icons and skins), which are served from the Sync Engine. 
These can be packed into composite image files to nninimize download time. 
At the same time the Altiolive Client is subscribed to any Data Pools so that they receive 
5 relevant updates to the initial data set Data Pools are shared across clients, and track 
changes firom the initial data sent to each client Data Pools collect updates fi:om the back- 
end application ether by polling to a URL at regular intervals (HTTP polling) or by having 
updates streamed through JMS, an HTTP streaming connection, or Socket (direct 
connection). This is configurable per Data Pool. 

10 Independently to the Data Pool configuration, the Client can receive updates by regular 
polling or through HTTP streanaing (note that some browsers do not support streaming 
connections). The user can submit updates through the Client. These are mapped onto 
Service Functions issued by the Synchronization Engine, which in turn submit the updated 
data to the back-end application. These update methods can map to existing HTTP post 

15 methods on the back-end application if available. 

Every Data Pool must have a service fiinction associated with it to provide initial data; 
however the reverse is not necessarily true, as some service functions will provide static data, 
which is not expected to change during the user's session. 

If there are images that are data related (e.g. thumbnails), then the Image Data is requested 
20 from the back-end application when the Client requests it, via image-specific service 
fiinctions. 

User Preferences 

If the user changes the state of their desktop (window positions, state) the changes can be 
25 optionally posted to the Synchronization Engine and saved locally or on a shared store (e.g. 
in an external database through a JDBC connection). This allows the users desktop to be 
restored when they next log in. This setting is made in the Sync Engine for all applications. 



wo 02/065286 



PCT/GB02/00578 



55 

The ROS Demonstration 

Firstly, there is no specific back-end application installed. The demonstration is built entirely 
using the AltioLive Developer Edition and takes advantage of the bundled AltioLive 
Development Prototyping Kit (ADPK). This simulates the back-end application through its: 
5 Login handler — used to create the session when the user logs on, and serve the AltioLive 
application host page (called AltioLogin). 

XML Database - a general-purpose configurable in-memory XML database (called 
AltioDB) that accepts scripted updates (hence the ability to create dynamic price changes) 
10 and persists data to flat files (hence any bids you have made reappear when you next log on). 

Logging-on 

When you select the demonstration option, the login handler generates the log-on screen. 

When you log on, the login handler creates a session object with specific tags to identify the 
15 application and the View. In this case ros (which you typed in as Application) is the 

application and the View is preconfigured in the Login Handler to roslive for all users. 

Once youVe logged-on, the login handler serves the Richmond Office Supplies Host Page 

(roshtml.txt) which in turn defines the space for the AltioLive Desktop and invokes the 

AltioLive Client The AltioLive Client then connects to the Synchronization Engine, which 
20 accesses the session parameters to determine that you are using the ros application with the 

rosKve View, 

The Initial View 

The Synchronization Engine serves the View -file,- ros/views/roslivcxml, to the client, 
25 which defines: 

• The open windows Le. This is AltioLive and Offers and Bids 

• The three minimized windows ie. Offers I Watch, My Bids and My Offers 
For Sale 

• The windows that can be activated by the user e.g. Create New Bid 
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• The controls on each window and how they are populated with data from the 
XML desktop. 

• The event-action rules e.g. open Create New Bid for the selected row in the 
LIST when the toolbar button is clicked. 

5 If you had previously accessed the View, then it will be automatically modified according to 
your saved user preferences e,g. window positions and states. 

The Initial Data 

The Synchronization Engine serves the initial data (to populate the XML desktop) according 
10 to the information associated with the View (Figure 8). This is defined in the Designer, on 

the View tab. Initial Data node. In this case there are four service functions used to get initial 

data. Of these, GET_FORSALE and GET_WATCH both subscribe to datapools. 

The Synchronization Engine substitutes the Server Commands for the XML data returned 

from the Service Function specified in the SVRCMD. 
15 The catalog data is static and so the server command just invokes the GET_CATALOG 

service function, which returns the XML data for all catalog items (e.g. the product id, 

description, thumbnail etc). 

The items for sale and their corresponding bids, however, need to be updated live in the user 
interface so you can see new offers or bids or changes to data as they are made. Therefore 
20 the include statement not only invokes the GET_FORSALE service function to return this 
initial data set but also subscribes to the NEW_FORSALE Data Pool so that any updates 
are streamed to the client. The individual portfolio of items tiiat you are interested in also is 
subscribed to a Data Pool in order to show you things that you have dropped into the 
watch-list More information on this is in the next section. 

25 

Service Functions And Data Pools 

The application configuration file, ros/altioapp.xml, is used to configure the Service 
Functions and Data Pools for the application. All service fiinctions in ROS are HmP-based. 
An example Service Function is shown in Figure 9. 
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This definition states that when the GET_CATALOG Service Function is invoked, an 
HTTP URL request is executed with the specified arguments. In this case, the target is the 
XML Database (AltioDB) and the arguments specify that the CATALOG data set should be 
returned. 

Note: Service Functions do not define the format of XML data that is returned and one of 
the features of AltioLive is that it accepts any valid XML data. 

The datapool in Figure 10 is used to get updates of items, which the user has placed, on 
their watch list The TEnter Text* field contains the XPath information used in the Filter. (It 
is only displayed here so that you can see the entire XPath statement used in the Filter). This 
ensures that only items that the logged on user has added to their list are passed into the 
datapool. The AltioLive Client uses this to create a personalized watch list The subscription 
is filtered by user-id so that the user does not see the items others have added to their 
portfolios. The predicate @USR=${session.logon.name} syntax controls this. The Pollrate 
specifies how ofi:en updates should be passed to the client, in this case every 1000 
milliseconds (1 second). 

Submit New Offer 

When you submit a new offer from the "Create New Offer For Sale" window you select a 
product firom the list, enter details in the various fields, and click the "Submif button. The 
20 Submit button has an action rule that invokes a NEW_SALE Service Function, as shown in 
Figure 11. Again, the TEnter Text* field includes the fiill URL argument (which is partially 
obscured in the upper box). This Service Function creates a new SALE_ITEM element in 
the FOR_SAIE table. Again the target is AltioDB and in the arguments the GUBD assigns 
the unique ID (which AltioDB creates when adding an_element) to a S ALE_ID attribute. 
25 ONSUCCESS and ONFAILURE define the message that you see if the update succeeds or 
fails. The APP_ID is used to ensure the service call goes to the correct back-end 
application, and the SELLER_ID is set to the logged on ${session.logon.name} taken firom 
the session parameters. The SRVPARM list maps the named fields in the "Create New Offer 
For Sale" window to those expected by the back-end application. In this case we have the 



10 
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freedom to use the same names. For example, the data for product is scraped from the 
control NM="PROD" - the row selected in the 'Troducf' column in the list of products. 
The Data attribute created by the server in the new SALE_ITEM with this data in it is also 
specified as PROD. 

5 The SALEJTTEM created by this Service Function will look something like this: 

<SALEJTEM SALE_ID="S05" SELLER_ID="Mar/' PROD="Lever arch" 
PROD_ID="ID06" QTY="1" PRICE="11" CURRENCY="USD" 
SH.TRMS="FOB" PORT="North Pole" CmY="SWE" EXP_DATE="20001022» 
COMMENT="Beyond words."> 

10 

Where you need to create data that is not shown on the window, as is the case with the 
product ID (PRODJD), this is achieved by using hidden fields or columns. Thus for the 
PROD_ID the column is included in the "Select a Product" list but it has a width of 0, and 
hence is not displayed. 

15 

Submit New Bid 

When you submit a new bid from the "Create New Bid" window, the "Create New Bid" 
window shows the detaQs of the "Offer For Sale" item that was selected, and allows the 
relevant details for the bid to be entered. Once the information is entered in the fields the 
20 "Submit" button is clicked. The button has an action rule, which calls a NEW_BID Service 
Function as shown in Figure 12. 

This Service Function differs from the previous example (NEW_SALE) in that the BID 
element has to be inserted as a child of the SALE_ITEM that it corresponds to. Hence the 
TARGET IS set to SALEJTEM - where the SALE_ID is equal to the SALE.ED of the 
25 offer selected in the "Offers and Bids" window; which is passed to the "Create New Bid" 
window. NAME=BID specifies that a BID element is to be inserted. GUID=BID_ID 
specifies that the BID_ID is set to the generated unique ID. The remaining SRVPARMs are 
set to the data as input in the 'Create New Bid* window. The BID inserted under 
SALEJTEM by this Service Function wiU look like this 
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<SALE_ITEM SALE„ID="S05" SELLER_ID="Mary" PROD="Lever arch" 
PROD_ID="ID06" QTY="1" PRICE="11" 

CUKRENCY="USD" SH_TRMS="FOB" PORT= "North Pole" CTRY="SWE" 
EXP_DATE="20001022" COMMENT= "Beyond words."> 

<BID BID JD="B13" BIDDER^ID="Steve" PROD="Lever arch" 
PROD_ID="ID06" QTY="1" PRICE="6.30" 

CURRENCY="USD" SH^TRMS="FOB" PORT=" South Pole" CTRY="FIN" 
EXP_DATE="20001022" COMMENT="Ring the bell when delivering."/> 
</SALE_ITEM> 



10 

Image Handling 

The AltioLive Client downloads data images on demand An example of this can be seen by 
looking at the catalog of products that is displayed when the "New Offer" button is clicked. 
When the "Create New Offer For Sale" window is displayed, the images for the first four 

15 items in the product list are downloaded. If you scroll down the list you will see a slight delay 
(usually about half a second) as new images are downloaded for the products in the lower 
part of the list Notice that if you have scrolled through the list before, all of the images have 
already been downloaded, and thus the response is instant This method of image handling 
results in improved performance, allowing applications to include rich image content without 

20 incurring a long initial download time. The code required to achieve this is given below. 



<COLDATAFLD="THUMB" TYPE="IMG" W="40" 
IMGSVRCMD="GET.APPIMG"/> 



25 This element specifies the column of the "Select a product' list, including a GET_APPIMG 
image server command - shown in Figure 13. The image server functionality of the client 
handled when this Service Function is called, i.e. when the image is first displayed. The data 
for the list the column specifies is in //ITEM as its node. In the column a data field of 
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//TTEM, THUMB is specified This contains the directory path and name of the image e.g. 
TH:UMB="img/CalculatorTN.jpg". 
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Appendix II 
Integrating AltioLive 

from Altio limited; Volume 4 Chapters 1- 5 of the AltioLive User Documentation. 

5 

Introduction 
Welcome 

10 This document explains the system operation of AltioLive and how it is configured to 
integrate with existing applications. This covers various areas, from configuring controls to 
advanced issues of style, recommended practices and optimising performance. 
Many examples in this document are drawn from the ROS (Richmond Office Supplies) 
example application. This allows you to see how to achieve particular results, and you can 

15 see working examples in the application. 

The examples show the XML code of the application configuration and data, as explained in 
the API Guide. Each XML attribute maps direcdy on to the matching property of the 
control in the Designer. Each control corresponds to an XML element 

Readers should be familiar with the other Altio documents - in particular 
20 • Getting Started 

• Online Help 
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Technical Overview 

Describes llie overall operation of AltoLive and how the components of AltioLive integrate 
and operate to create a live dynamic interface. 

5 

Glossary 

Provides abbreviations and icons used throughout tiie document 

Application Server Integration 

10 Configuration of the Sync Engine to support creation of Service Functions to integrate one 
or more applications with the Sync Engine. It covers: 

• Initial Data 

• Datapools 

15 ♦ Client to Application updates 

• Image data 

• Service Functions 

• Communication options 

20 Data Sync 

Addresses the mechanisms used to update data (through Datapools) on the Client It 
covers: 

• Timestamps 

25 • Datapool longevity 

• Deleting data 

• AL.IDs 

• Client update 
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Hosting the Client 

Invoking the Applet from the Host Web page. It covers: 

5 • Standalone 

• Debug mode 

• Browser compatibility 

• Dynamic mode 

• links to Javascript 

10 

Logon Process 

Addresses the mechanism of logon process and session creation. It covers: 

• Session Creation 

15 • Altio Logon Process 

• Independent Logon 



Skins 

Customization of tiie look of the Client through the use of Skins. It covers: 

20 

• The Outiine Skin 

• Showing the window is active 

• Resizable windows 

• Window controls buttons, toolbar buttons and icons 
25 • Composite images 
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Creating a Custom Jar 

Building a custom Jar to increase the download speed and efficiency. 

5 Sync Engine Management 

Covers 

• The Sync Engine Admin Tool 

• The Application Manager 

10 Data Referencing and XPath 

Some examples of different methods of using XPath. 
Configuring Controls 

Tips on using the Designer to configure controls. 

15 Data Filtering 

Examines methods of selectively providing data. 

More Information 

Further information on configuring AltioLive is contained in the online AltioLive API Guide 
20 and Operating and Maintaining Altiolive. Information on installing Altiolive is provided in 
the AltioLive Server Installation Guide. Support can be reached by sending email to 
<;upport@.altio.com . 

To send feedback to Altio on this manual, send email to: feedback@altio.com 

25 

CHAPTER 1 - Technical Overview 

The system architecture of an AltioLive application is shown in Figure 14. 



Where: 
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• The application interface is accessed through a Host Page, which invokes the 
AltioLive Client applet. The Client is a small footprint applet targeted at Java 1.1 
Virtual Machines (lEA and above, Netscape 4 and above)- for maximum browser 
compatibility. 

• The Client accesses the AltioLive Sync Engine. This is implemented as Java Servlets 
for use on Servlet engines, which support JSDK 2.0 to allow installation on common 
Application Servers. 

• The look, feel and operation of the Application interface is defined through the Altio 
XML API (see AltioLive API guide). In establishing communication, the Client 
requests the Sync Engine to serve it with this definition which it creates from the 
Default XML (predefined by Altio), the Application Configuration XML and user 
preferences from any previous sessions. 

• As part of its Application Configuration, the Client requests the Application Images 
(i.e. backgrounds, button images, icons and skins), which are served from tiie Sync 
Engine. These can be packed into one or more composite image files to minimize 
download times. 

• The Sync Engine also processes the Data Configuration XML This specifies Service 
Functions (defined in the Server Configuration XML) lhat request the Initial Data 
from tiie Application to be served to the Client where it is saved in the XML 
Desktop and rendered to tiie user. 

• If there are images that are data related (e.g. thumbnails) ratiier than Application 
related, then the Image Data is requested from the Application when the Client 
specifically needs it using image specific Service Functions. 

• The Data Configuration XML also subscribes the Client to Datapools within the 
Sjnc Engine. The Application updates tiie Initial Data by eitiier polling for, or 
streaming, Data Updates from the Sync Engine. The mechanism and frequency is 
configured per Datapool in the Application Configuration. 

• Datapools are shared across Clients and track changes from the Initial Data sent to 
the first Client. The status of a specific Client's XML Desktop in relation to 
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subscribed Datapools and data on the Application is maintained through a 
tiniestamp/sequencing mechanism, 

• New Data is either polled-from or streamed-to the Client asynchronously to 
maintain the XML desktop. 

• Updates from the Client (i.e. data that has been entered by the user) are passed to the 
Sync Engine and posted to the Application through a Service Function that can be 
mapped on to its existing HTTP post interfaces. The effect of the update is reflected 
through the previously described Datapool mechanism and/or through user 
confirmation. 

• If the user changes the state of their desktop (window positions, state) then these are 
posted to the Sync Engine. According to the Server Configuration, these are saved 
locally, saved in an extemal database through a JDBC connection or posted to the 
Application. 

• Sync Engines can be clustered/distributed to serve large communities of users using 
a Master-Slave configuration. 

CHAPTER 2 - Application Server Integration 
Overview 

Figure 15 shows the interaction between the Sync Engine and the Application. 

There are three key areas: 

1. Data Service Functions that request the Initial Data and then pass updates to the 
Application 

2. Image Service Functions that request Data-specific images 

3. Datapools, which update the Initial Data. 
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Initial Data 

The Data Configuration defines the Initial Data set for the Client. This invokes one or more 
Service Functions to request data from the Application tiiat is then served to the Client 



An example Data Configuration is shown below: 



5 



<ALTIO> 




<DATA> 




<USER NM="to_be_set. 


_by_SyncEngine'7> 


<INCLUDE SVRCMD= 


"GET_CATALOG7> 


<INCLUDE SVRCMD= 


"GET.FORSALE" SUBSCRIBE="NEW_FORSALE" 


SUBSCRIBEu^GS=' 


'7> 


</DATA> 




</ALTIO> 





The INCLUDE elements can be considered as effectively substituting the XML data 
15 elements returned by the Service Function before the data is passed to the Client 

In the case of the GET_CATALOG Service Function, the catalog data it returns is static 
data (i.e. not updated during the user session) and therefore it does not subscribe to a 
Datapool. In the case of the GET_FORSALE data, this is live' data subscribed to tiie 
20 NEW_FORSALE Datapool. The name used in a SUBSCRIBE should correspond to a 
Datapool definition in the Application Configuration file. 

The SUBSCRIBE_ARGS attribute can be used to apply filters to a Datapool i.e. to restrict 
which updates to the data set are passed onto the Client In this case no filter is set so all 
25 Clients get all data updates. The value for SUBSCRIBE_ARGS can derive from session 
parameter values using the '{} ' syntax (see API Guide). 
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The USER NM attribute is optional and is a mechanism to make the User Id (from the 
session) accessible in the Client. An example is given in the Configuring Controls section. 

Datapools 

Datapools provide a method for distributing updates to multiple Clients. Each Datapool 
definition creates a single Datapool, which is instantiated when the first Client subscribes. 

Datapools track changes to the Initial Data sent to the Client and received from the 
Application using timestamp information in the Datapool and in the Initial Data. 

In a Master-Slave configuration, the Master Sync Engine receives the updates to the 
Datapools from the Application. The Slave Sync Engine communicates with the Master Sync 
Engine to receive the updates in its Datapools. The Client(s) polls for or is streamed to the 
updates in the Datapools of the Slave Sync Engine. 

In a single Sync Engine configuration, the updates are received in the Datapools of the Sync 
Engine from the Application, The Client(s) either polls for or is streamed to the updates 
from the Datapools. An example Datapool definition from a Server Configuration is shown 
below: 

<DATAPOOLS> . 
<DATAPOOLNM='NEW_SALE* CACHESIZE='800' 
ARCHrVEFII£NAME='C:\syncengine\Data\ArchiveNewNews.to^ 
<MASTER DATAPATH=7/FOR„SALE* SENDTIMESTAMP='N'> 
<MASTERHTrP 

POLLRATE='2000* URL="http://server.name/servlet/com.altio.demodbX)emoDB" 
URLARGS=*'ACnON=GET&PARENTrAG=FOR_SALE" /> 
<TIMESTAMP ELEMENT=7/FOR_SALE* 
ATTRJBUTE=TIMESTAMP* TYPE='INTEGER' FORMAT='#'/> 
</MASTER> 
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<SLAVE> 

<SLAVEHTrP POLLRATE="20007> 
</SLAVE> 
</DATAPOOL> 
</DATAPOOLS> 



This defines the NEW_FORSALE Datapool where: 



NM 


Specifies the name of the Datapool. 


CACHESIZE 


Specifies the cache size of the Datapool. 


ARCHIVEFILENAME 


Specifies the relative pathname of the file where the old 
entries to the Datapool are archived. For example, if 
Cache size is set to 800, the last 800 entries are held in the 
Datapool. All the earlier entries are archived to a file. 


Attributes for Master Sync Engine communication with the Application 


DATAPATH 


Specifies an XPath definition that specifies the subset of 
elements to extract firom the application XML and then 
pass on as data updates. 

It defaults to ihe full XML returned by the application. 


SENDTIMESTAMP 


Specifies whether the Sync Engine should send the 
Timestamp with the update. 


MASTERHTTP, 

MASTERHTTPSTREAM, 

MASTERSOCKET 


Defines the communication option — in this case HTTP 
Polling. Note... The Communication is defmed per 
Datapool. 


URL 


Defines URL of a fiinction on the Application that is used 
to request updates. This attribute is specified if the 
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communication protocol is set to HTTP Polling or 
Streaming. 


URL ARCS 


Specifies additional parameters passed in the HTTP Post 
Method — necessary if ihe Application function is non- 
specific (i.e. has multiple metiiods). This attribute is 
specified if the communication protocol is set to HTTP 
Polling or Streaming. 


POLLRATE 


Defines the poll rate interval for HTTP polling in 
milliseconds. This attribute is specified if the 
communication protocol is set to HTTP polling. 


IP 


Defines tiie IP address of tiie machine on which the back 
end Application is installed. This attribute is specified if 
tiie communication protocol is set to Socket 


PORT 


Defines die port for the conmiunication protocol is set to 
Socket This attnbute is speaned if the communication 
protocol is set to Socket 


ELEMENT 


Specifies the element within the returned data update that 
would contain tiie Timestamp. The element should be 

SpcCincU ao all u^l aUl <^UCry dUlLCIllClXU 


ATTRIBUTE 


Specifies the attribute within the element specified tiiat 
would contain tiie Timestamp value. 


TYPE 


Specifies tiie return type for the Timestamp. It can be set 
to INTEGER or DATE type. 


Fonnat 


Specifies the Format in which the Timestamp is returned 
witii tiie data update. 


Attributes for Slave Sync Engine communication with the Client 


SLAVEHTTP, 
SLAVEHTTPSTREAM, 


Defines tiie communication option - in this case HTTP 
Polling. Note: The Communication is defined per 
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SLAvESOCKET 


Datapool. 


POLLRATE 


Defines the poll rate interval for HTTP polling in 
milliseconds. This attribute is specified if the 
communication protocol is set to HTTP polling. 


PORT 


Defines the port for the communication protocol is set to 
Socket This attribute is specified if the communication 
protocol is set to Socket 



In this case this is a polled definition, so an HTTP request is made every 2 seconds by the 
Master Sync Engine to the Application with the following parameters: 

action=GetForSaleServlet&TIMESTAMP=nnnnn 



Where TIMESTAMP is the last value for the Datapool (see next Chapter), 

On receipt of an update, the Master Sync Engine adds the update to the queue of updates to 
be sent to the Slave Sync Engine. The Slave Sync Engine polls for the Update every 2 
seconds. On receipt of an update, the Slave Sync Engine adds the update to the queue of 
updates to be sent to the Client(s). 

Client to Application Updates 

The Client updates the Application (i.e. to add/modify/delete data) by invoking a Service 
Function with parameters. This is defined in the View Configuration. 

An example update request firom a View Configuration is shown below: 
<BUTrON H="30" W="70" X="90" Y="270" CAPT[ON="Submit" > 
<ACTIONRULES TRIGGER="CUCK"> 
<ACTIONRULE DESC="Description of action rule"> 
<CONDmONS/> 
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<ACTIONS> 

<ACTSERVER CMD="NEW_BID" WINDOWSTATE="HIDE" 
DATATyPE="WINDOWDATA"/> 
</ACnONS> 
</ACTIONRULE> 
</ACTIONRULES> 
</BUTrON> 



When the button captioned 'Submit' is pressed, the Client invokes the Service Function 
10 named NEWJBID and passes (as parameters) the name and value of all controls within the 
current window that have an NM attribute defined (i.e. they are named controls)* There are 
two exceptions: 

• IMAGE - named-image passes blank values 

15 • LIST - lists use the nanied columns of the selected row. If no row is selected then a 

blank value is used for each named column. The list itself does not have to be 
named. 

Service Functions return a success/fail status back to the Client with an optional message 
20 and optional parameter name which are treated as follows: 

• If successful and there is no message, then nothing is displayed to the user. 

• If successful and there is a message, then this is displayed in a 'success' pop-up 
window. 

25 • If unsuccessful and there is a message defined, then this is displayed in a 'failed' 

pop-up window. 

• If unsuccessful and there is no message, then nothing is displayed to the user. 

• If unsuccessful and there is a parameter control name, then the associated control is 
selected ^.e. cursor positioned on field in error). 
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Image Data 

Data related images (e.g. thumbnails of catalog items) are requested from the Application (by 
the Client) through image request Service Functions. To avoid start-up delays, these images 
are only requested when they have to be rendered in the user interface, e.g. if a list contained 
5 images, only the visible images are requested. If the list is scrolled then more images will be 
requested. Images are cached on the Client once received and are not re-requested. 

An example image request from an Application Configuration is shown below: 
<PANEL> 

<IMAGENM="IMAGE" DATAFLD="THUMB" 
IMGSVRCMD="GET_APPIMG" H="80" W="80" X="260" Y="180" 
DATA=7/ITEM[@PROD_ID='(SALE_LIST@PROD.ID) B0RDERW="5" 
FILLC0L=*'#FFFFFF7> 

<TEXT H="20" W="100'' X="120" Y="20" CAPTION="Product:" 
EDITABLE="N" DATAKLD="PROD7> 

</PANEL> 



The DATAFLD specifies the attribute name in the element selected in DATA that holds the 
20 name of the required image. The IMGSVRCMD specifies the Service Function used to 
request the image (using tiie value of the attribute specified by the DATAFLD). In this case 
it will pass the value of the THUMB attribute in the specified element of DATA. 

Service Functions 

25 Service Functions define HTTP requests used to send and/or request data from the 
Application (for Initial Data and/ or updates). 



10 



15 
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Whilst they are defined independendy from the Application (thereby allowing miiltiple use of 
the Service Function) it's useful to consider some specific instances for: 

♦ Requesting Initial Data. 

5 • Requesting an update on the server. 

• Requesting an image. 

They are designed to provide simple integration with the Application and (m the case of 
updates) to map onto existing HTTP post requests. 
10 To have an acknowledgement message sent to the client after calling a service function, use 
the following steps: 

1 . In the Application Manager, edit the Service function. 

2. Under Acknowledgement, set the Source to Response. 

15 3. Click OK to accept, then validate and update the ApplicationConfig.xml file. 



20 



25 



Requesting Initial Data 

An example Initial Data request (GET„CATALOG) Service Function from a Application 
Configuration is shown below: 



<SERVICE NM="GET_CATALOG" 
URL='*http://server.name/servlet/com.altio.demodb.DemoDB" 
URI^GS==''ACTION=GET&PARENTrAG=CATALOG" ADDQ="N*' 
DOCTYPE^"XML" GETDATA="Y/> 

<SERVICE> 



Where: 



URL 



Defines URL of the Application function that will be invoked by the 
Service Function. 
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URL_ARGS 


Defines the additional parameters - necessary in this case, as the 
Application function is general purpose. 


DOCTYPE 


Specifies the type if data that is expected - in this case XML data. 


GETDATA 


Specifies whether the data returned by the Application should be served 
to the Client — in this case it is 



The Application in responding to this Service Function should supply XML formatted data. 
If the Datapool mechanism is to be used (i.e. to feed dynamic updates to the client) then the 
first tag must include a TIMESTAMP attribute e.g.: 



10 



<CATALOG TIMESTAMP="12890"> 

<rrEMPROD="Calculator" PROD_ID="ID01" PRICE="4.49" 

DESCR="The best calculator around" /> 

<rmMPROD="Chair" PROD_ID="ID02" PRICE="69.50" 
DESCR="Comfortable and relaxing..." /> 

</CATALOG> 



Refer to next Chapter for use of timestamps. 

15 Requesting updates to the application 

An example data update request (NEWJBID) Service Function firom an Application 
Configuration is shown below: 



20 



25 
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<SERVICE NM="NEW_BID" 
IIRL= "http: / /server.name / servlet/com.altio.demodb.DemoDB" 
UMARGS=''ACTI0N=NEW&PAKE2>JTrAG=SAI£JTEM&a^^^ 
D=SALE_ID&amp-N[AME=BID&GUID=BID_ID" ADDQ="Y" 
DOCTyPE="XML" GETDATA="N" ACfCSRC= "HEADER" 
ACKTYPE="SUCCESS" ACK="Added record"> 

<ONSUCCESS MSGSRC="DEnNE" MSG="Your bid has been accepted7> 
<ONFAILUREMSGSRC="DEFINE" MSG="Therewas a problem processing 
yourrec[uest"/> 

<SRVPARM SERVER="SALE_ID" CLIENT="SALE_ID"/> 
<SRVPARM SERVER="BIDDER^ID" CLIENT="{logon.name}'7> 
<SRVPARM SERVER="QTY" CLIENT="QTY"/> 
<SRVPARMSERVER="PRICE" CLIENT="PRICE7> 



</SERVICE> 



Where: 


DOCTYPE 


Specifies the type of data that is expected - in this case general text 
(i.e. not XML or an image). 


GETDATA 


In this case specifies that it should not be returned to the Client 
Note: It should not be set to '*Y" if the DOCTYPE is not ''XML". 


ADDQ 


Defines whether single quotes should be put around the parameter 
values passed with the request. 


ACKSRC 


Defines the source of response message. Set it to RESPONSE to 
search for a response message defined in the Application. Set it to 
HEADER to search for Altio specific parameters (see below) in 
the HTTP response header. Set it to NONE if no message is 
required. 
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ACKTYPE 


Defines whether the Sync Engine should search for the response 
message after the Success or Failure of the Service Function. 


ACK 


Defines the Application defined response message that the Sync 
Engine searches for if the ACKSRC is set to RESPONSE. 


ONSUCCESS 
MSGSRC 


The Sync Engine can be set to serve the Client a message in a pop- 
up window, if the result of the Service Function was successful. 
Defines the source of message. Set it to DEFINE to send a user 
defined message. Set it to HEADER to return the Altio specific 
parameters (see below altio .message) in the Hi"!'!-' response header. 
Set it to NONE if message is not required. 


ONSUCCESS MSG 


Defines a confirmation message. The Sync Engine serves the 
message to the Client in a pop-up window on the success of the 
Service Function. The Text can be set only if Source is set to 
DEFINE. 


ONFAILURE 
MSGSRC 


The Sync Engine can be set to serve the Client a message in a pop- 
up window, if the result of the Service Function was a failure. 
Defines the source of message. Set it to DEHNE to send a user 
defined text Set it to HEADER to return the Altio specific 
parameters (see below altio.message) in the return HTTP header. 
Set it to NONE if no message is required. 


ONFAILURE 
MSG 


Defines a message. The Sync Engine serves the message to the 
Client in a pop-up window on the failure of the Service Function. 
The Text can be set only if Source is set to DEFINE. 


SRVPARAM 


Defines the parameters that are passed (and their order) with the 
request This also maps Client defined parameter names (which are 
derived from control names) to Application parameter names. 



In this case, this would result in an HTTP request with the following parameters: 
action=NewBid&SALE_ID='..'&BIDDER_ID='..'&QTY='..' &PRICE='..' 
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Note: The second parameter is a special case. CLIENT="[UID]" is used to define that 
the User ID defined in the session parameters is passed as the value for Bn)DER_ID. If 
other parameters from the session are to be used, then the {} syntax can be used to specify 
session parameter e.g. {logon.name} would have the same effect as [UID]. 

5 

The above method is good for integrating on a preexisting Application Interface and 
provides mechanisms for confirming the success/failure of the update. 

If the Application Interface can be modified, then the Application can set Altio specific 
parameters in the HTTP response header as follows: 

10 



altio.status 


Set to: 

• 0 indicates Success 

• 1 indicates failure (no message) 

• 2 indicates failure (with message). 


alticmessage 


If status =2, then this contains descriptive text that will be displayed to 
the user in the pop-up error window. 


altio.errfld 


Contains the server parameter name that caused the error. This is 
converted back into the Client control name and passed back to the 
Client so it can re-position back on the field. 



Requesting Images 

An example image request (GET ^APPIMG) Service Function from an Application 
15 Configuration is shown below: 



<SERVICES> 

<SERVICE NM="GET_APPIMG" 
UIU.=''http://server.name/servlet/com.altio.demodb.GetImageServlet" ADDQ= "N" 
DOCTYPE="IMG" GETDATA="Y"> 
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<SVIIPARM SERVER="APP" CLrENT="{logon.app} 7> 
<SVKPARM SERVER="IMG" CLIENT="IMG7> 
</SERVICE> 

</SERVICES> 



Where: 

URL Defines URL of the Application fiinction that will return the image. 

DOCTYPE Specifies the type if data that is returned - in this case an Image (i,e. 
PEG, GIF etc). 

GETDATA Specifies that the data requested by the Service Function will be 
returned to the Client 

SVRPARAM Specifies the mapping between parameters passed by the Qient in the 
service request to the Sync Engine into parameters passed by the Sync 
Engine to Application. Note: This must use CLIENT="IMG". 

In this case, this would result in an HTTP request being made with the following parameters: 
IMAGEURL=imageurlname 

Downloading data on demand 

Normally all data (apart firom context-dependent images) is downloaded onto the client at 
the same time as the applet. However, there are some circumstances where you may want to 
have data downloading, only if (or when) it is required by the user. 

If you have an action rule set up on a list so that when a user double-dicks on a row they get 
a list of related information in a separate window. If the related information is very large 
then it may be efficient to download it on demand so that time is not used downloading 
information that may not be required by the user. 
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1. Downloading sets of data on demand. 

This can be achiefved by taking the datapool subscription for the data out of the 
viewname_data.xml file and implementing it as an ACTSERVER action rule, triggered by a 
particular event. 

5 

Example: 

Rearrange the ROS demo data into a file of tiie sale items and a file of the bids and alter the 
service functions so that sale items are initially sent to the client and the relevant bids are 
only sent when a particular sale item is selected. 

10 

The action rule is placed on the list of sale items and looks like: 
Trigger = ONCHANGE 
Action = ACTSERVER 

Command = GET^BmS 
15 Data type = STRING 

Data = '{SALE_LIST@PROD_ID}' 
Data tag = PROD_m 
Window state = RESUME 

20 where Data tag and Data roughly correspond with attribute and value. 

The GET_BIDS service function has an XPath target statement requesting bids with a 
particular PROD_ID. 

2. Updates for the downloaded data set - data routing 

25 We can also assign a datapool to update this data. If we set the datapool as non-transient: 
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5 



15 



20 



<DATAPOOL NM=*SECURITIES_POOL' 
FILTER = 

VSECUmTIES/SECUmTY[/USERS/USER[@USER.ID=${sessionJogon.name}] 
USERSYMBOL/@NM=@SYMBOL]' 



</DATAPOOL> 



By calling a service function through an ACTSERVER action rule we cannot subscribe to a 
datapool so we cannot get updates. Luckily this is changing in the next software release 
10 where we have introduced tiie idea of non-transient datapools. We can create an entry in a 
second datapool tiiat acts like a temporary subscription to the main datapool containing all 
tiie updating data. Hence we can temporarily request updates for a particular set of data 
when we open a window and automatically cancel the updates when the window is closed. 



Commimication Options 

The mechanism used for Service Functions is always the HTTP POST Metiiod. This Sync 
Engine will accept GZIP and ZIP compression formats in response to these requests to 
minimize traffic volumes from tiie Application. 



Three mechanisms are available to provide New Data to tiie Datapools: 

• HTTP Polling - wherein the Sync Engine periodically polls tiie Application for 
updates. 

• inrP Streaming - wherein tiie Sync Engine opens an HTTP Request and the 
25 Application sends updates as they occur. 

• Socket - as per streaming but using the underlying socket mechanism. 



The mechanism is specified per Datapool. 
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Of these three mechanisms, the first is normally the easiest to implement against an existing 
Application (as it requires least change to the Application architecture). The latter two are 
mechanisms for rapidly changing data. Note: None of these three mechanisms accept 
compressed data format (they should only be handling small data sets) 

5 

If the SOCKET mechanism is used then the Sync Engine will automatically add an 
additional parameter in the HTTP request SOCKET="nn" to specify the socket address for 
the Application to use in responding with data. 

10 Data formats 

Date and time data is expected in AltioLive in the format 
YYYYMMDDTHHMMSS +x 

Where the Time part (THHMMSS +x) is optional, and the GMT offset of the server (4-x) is 
also optional. 

15 

Other notes 

1. The Sync Engbe does not check that the returned data matches the DOCTYPE. 

2, The Sync Engine will output a warning if the parameters provided by the client do 
not match those defined in the Service Function. 

20 3. URL JUIGS if specified are posted before SWPARAM values. 

4. When using HTTP Polling, the first poll occurs immediately. 

5. The Sync Engine is inactive until the first user connects. 

Whilst one Service Function can be used for Initial Data it is often better to define a number 
25 of Service Functions ifi 
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• There are multiple Datapools in use 

• Data is separately time stamped 

• Service Functions are shared across a number of Application Configurations which 
5 define an interface which uses different data sets 

• Data is sourced from multiple Applications. 

• Its better to have smdl Datapools for specific data rather than an all-embracing large 
Datapool. This allows more control over refresh rates and avoids conflicts over 
XML attribute names. 

10 •Its better to filter data on the Sync Engine than on tiie Client 

CHAPTER 3 - Data Sync 
Overview 

15 The Datapool mechanism is used to update multiple Clients firom a single update firom the 
Application — wherein only the XML element that has changed is sent to tiie Client. 

Timestamps 

Each Datapool has an associated Timestamp, This is in the form of a long integer value or in 
20 Date/Time format 

The Timestamp is initially set when the first Client subscribes to the Datapool and receives 
its Initial Data (in which there must be a TIMESTAMP=nn attribute in the initial tag). 

25 Thereafter, the Timestamp is updated whenever, the Sync Engine receives updated data 
firom the Application whetiier by polling (in which case it passes its current value in die 
request) or tiirough streaming. The new Timestamp is specified as an attribute in tiie initial 
tag of the response. 
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The interpretation of the Timestamp is determined by the Application and is specific to each 
Datapool ^i.e. Altiolive does not specify whether the number is milliseconds, seconds, next 
sequence number etc). However, the Timestamp must get numerically larger with each 
5 update. 

The Timestamp is sent an integer or date/time format. It should support the expected 
lifetime of an Application. In the unlikely event that the Timestamp has to be reset, then the 
Sync Engines would need to be reset. 

10 

A Timestamp parameter accompanies the Data Update request sent by the Sync Engine to 
the Application. In some cases, while integrating an existing Application with AltioLive, it 
would be necessary to exclude the Timestamp parameter firom the Data Update request. 

By default, the Application returns the Timestamp value as an attribute of the parent node of 
15 the data update posted by the Application. However, the Timestamp can be retrieved from a 
specified element attribute firom the data update received firom the Application in a specified 
format. 

If for any reason, an update is received with a duplicate of an earlier Timestamp ihen the 
Sync Engine will output a warning message. 

20 

Datapool Longevity 

The Datapool effectively has an entry per timestamp. The size of the Datapool is determined 
through the CACHESI2E attribute. By default this is set to 800 entries, which means that 
the last 800 updates are held in the Datapool. 

25 

The required size of the Datapool depends on the firequency of update to Clients and the 
frequency of update from the Application. If the Client were to poll at 3-second intervals 
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and the Application creates updates at a rate of 2 per second, then it should be set to at least 
four times the rate (i.e. 4*3*2=24) to provide contingency. 

The last number of updates equal to the quarter of the cache size per Datapool are cached in 
5 memory. Earlier updates are archived to disk. For more details see the Datapool topic in the 
API guide. 

Deleting Data 

To update an XML element or insert a new XML element in the XML Desktop, the 
10 Application simply has to supply the element through the Datapool mechanism. 

However, to delete an element, the AL_ACTrON=DELETE attribute must be added to the 
element (specifying sufficient attributes to uniquely identify the element) 

15 For example, the following XML updates the description of the chair and deletes the 
calculator 



20 



<CATALOG TIMESTAMP="12891"> 

<ITEMPROD="Calculator" PROD_ID="ID01" PRICE="4.49" 
AL ^CTION="DELETE" 

DESCR="The best calculator around" /> 
<ITEMPROD="Chair" PROD_ID="ID02" PRICE="69.50" 
DESCR= "Comfortable and relaxing and now in brown suede" /> 
</CATALOG> 



25 AL IDs 



Data elements that are updated in the XML Desktop need to be uniquely referenced and 
Altiolive uses an AL_ID attribute to define a unique key for each element The Sync Engine 
through the DATAKEYS definition adds these AL^IDs. 
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An example Datakeys definition firom a Server Configuration follows: 



<DATAKEYS> 




<DATAKEY NM= 


:"ITEM" PREFIX="CAT"> 


<FIELD NM= 


"PROD_ID7> 


</DATAKEY> 




<DATAKEYNM= 


="SALE_rmM" PREFIX="SALE"> 


<FTF,T,nNM= 


"SALE_ID7> 


</DATAKEY> 




<DATAKEYNM: 


="BID" PREFIX="BID"> 


<FTF,T,DNM= 


"BID_ID7> 


</DATAKEY> 




</DATAKEYS> 





Where: 
15 DATAKEYNM 

Specifies the name of an XML element tag - in this case <ITEM. . . / > 

FIELD NM 

Specifies the attribute name within the element whose value is used as the key — therefore 
20 this attribute should have unique values within all elements of the same type. 

PREFIX 

Specifies a prefix that is added to differentiate between different types of element that might 
otherwise have non-unique values. 

25 



The result of the first DATAKEY definition on the following data would be as follows: 
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10 



15 



<CATALOG> 

<ITEMPROD="Calculator" PROD_ID="ID01" PRICE="4.49" 

DESCR="The best calculator around" /> 
<ITEMPROD="Chair" PROD_ID="ID02" PRICE="69.50" 

DESCR= "Comfortable and relaxing..." /> 
</CATALOG> 



becomes: 



<CATALOG> 



<ITEM AL„ID="CAT.ID01" PROD="Calculator" PRODJD="ID0r' 
PRICE="4.49" 

DESCR="The best calculator around" /> 
<ITEM ALJD=»CAT_ID02" PROD="Chair" PROD_ID="ID02" 
PRICE="69.50" 

DESCR="Comfortable and relaxing..." /> 
</CATALOG> 



Client Update 

Datapool updates are either polled from the Sync Engine by the Client or streamed to the 
20 Client 

In the case of Polling: the Client polls the Sync Engine using its current Timestamp(s) (either 
the Initial Data or last successful poll). In response to the poll, the Sync Engine will send all 
updates (for all Datapools subscribed by the Client) subsequent to the Timestamp. 



25 In the case of Streaming, the Sync Engine maintains a queue of Clients that are subscribed 
for streamed updates. As the Datapool is updated, the relevant updates are added to a queue 
for each Client 
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Other notes 

1. The Client Queue is fixed length (16 entries). In the event of a queue being fiill (only 
likely if the Application generates updates at a high rate and/or the Client is 
subscribed to many Datapools), Datapool updating will suspend for up to 30 

5 seconds to allow the queue to clear. If the queue is still fiill after 30 seconds, the 

Client session is terminated. 

2. In the event of the Client Queue being fiill/ disconnected, warning messages are 
output to the Sync Engine log. 

10 CHAPTER 4 - Hosting the Client 
Overview 

The AltioLive Client applet is hosted in a host HTML page specific to each customer 
Application and may occupy the whole page or share the page with HTML defined areas 
(usually firames) around the applet space. 
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Debug mode 

If the application is to be run in debug mode, the debug version of the applet needs to be 

specified, and the types of debug message given can be configured. 
______ 

5 <HEAD> 

<TITIJa>Demo</TrrLE> 
</HEAD> 

<BODYtopmargin="0" leftmargin="0" marginwidth="0" marginheight="0"> 
10 <applet code="com/altio/A]tioApp.class" 

align="baseHne" width="800" height="600" 
archive="Iib/clientDebugServer.jar"> 
<param name="CONFIGFILE" value="Demo.xniI"> 
<param name="STANDALN" value="Y'> 
15 <param name="DEBUG" value="SYSTEM APPLET CONFIG PAINT 

IPAINTTRACE lACTIONRULE ISERVERIO ITRACKING IPARSING IXPATH 
UNASSIGNED" /> 

</applet> 
</BODY> 
20 </HTMI> 

The values: SYSTEM APPLET CONFIG PAINT IPAINTTRACE lACTIONRULE 
ISERVERIO ITRACKING IPARSING IXPATH UNASSIGNED, are the available types of 
error messages. Those prefixed with an exclamation mark are turned off. 

where: 

25 



archive 


Specifies the applet file name. 


Code 


Specifies the main class for the client applet and must be set to 
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com/altio/AltioApp .class. 


align, width, 
height 


Define the location and fixed size of the AltioLive Desktop area within 
the page. The size of the Altio desktop can be set relative to the size of 
the browser window using the % setting e.g. 'Vidth = "100%" height = 
"99%" 


Param 


Parameter values that define the name of the XML Application 
Configuration (Note: there should be an equivalent Data Configuration 
file in this case named demoStandaln_data.xml) and that the applet is 
operating in standalone mode. 



Browser compatibility 

The above invocation works for most browsers. There is currentiy one known exception for 
Netscape 4.x running on the Macintosh. It only supports Java effectively with the MRJ plug- 
in installed. Also the Embed tag must be used instead of the Applet tag with additional 
parameters. See htmltemplate.txt for an example of how to detect and support this. 
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When using AltioLive in Dynamic mode it is necessary to change the HTML to reflect the 
connection to the Sync Engine. 



Figure 16 shows a typical example of this integration. 

5 

The user logs on to the Application through its Logon process. For the demos provided 
with AltioLive, an Altio Login page is provided. (This is purely for demonstration purposes 
and is not intended for use in final applications.) Either directiy (from the Logon page) or 
indirectiy (through other pages/menus) the user invokes the URL of the Host page. The 
10 Application then constructs and serves the Host page HTML that invokes the Client with 
necessary parameters. (See Chapter 6 Logon Process for further details.) 

Once downloaded, the Client establishes communication with the Sync Engine to access the 
Application definition (personalized for that user) and the data required. Ihis requires the 
15 Sync Engine to access the user's session which it should inherendy have access to either 
through co-location on the application server or through session propagation in a clustered 
application server environment 



An example of the applet invocation HTML would be; 

20 



25 



<applet code="com/altio/AltioAppxlass** 
align="baseHne" width="800" height="600" 
archive= ' ' clientDebugServer. j ar" > 

<param name="appsrc" value=" altioserver URL"> 

<param cookie="cookie string"> 
</applet> 



where the major differences are: 
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Appsrc 


Specifies the URL of the Sync Engine instead of a local file. 


Cookie 


Specifies cookie string (necessary for some Macintosh 
deployments because cookie information is not always inherently 
accessible to Java applets). This should not be used for LINUX 
client deployments. 



Debugging the Client - During system integration it is possible to enable debug output by 

tbe Client to the Java Console. Contact Altio Technical support for details. 

Javascript - Action Rules within the Application Configuration can invoke Javascript e.g.: 

<BUTTON H="30" W="80" X="200" Y="15" CAPT[ON="ALTIO.C0M"> 
<ACTlONRULES TRIGGER = "CLICK"> 
<ACTIONRULE DESC="Default Action"> 
<CONDITIONS> 

</CONDITIONS> 
<ACTIONS> 

<ACTJAVASCRIPTMETHODNAME="MYMETHOD" 
ARGS="BTNCLICK"> 
</ACTIONS> 
</ACnONRULE> 
</ACTIONRULES> 

</BUTTON> 
a final 



Or can invoke a Javascript function e.g.: 

<BinTON H="30" W="80" X="200" Y="15" CAPTION="CALCULATOR"> 
<ACTIONRULES TRIGGER = "CLICK"> 
<ACTIONRULE DESC="Default Action" > 
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10 



<coNDrnoNS> 
</coNDrnoNS> 

<ACTIONS> 
<ACTION_APP CMD="JAVASCRIPT" 

SCRIPT="caIcuIatorO" /> 
</ACriONS> 
</ACTIONRULE> 
</ACTIONllULES> 
</BUTrON> 



The actual Javascript method will be invoked asynchronously in a separate thread (ixi order 
to keep the applet responding). The Javascript action rule returns immediately and the 
actions continue with the next action if there is one. For this action rule to work a 
15 MAYSCRIPT tag is needed on the APPLET tag in the HTML page hosting the applet. 

Kg. <applet code="com.altioAltioApp" align="baseline" width="104r' height="702" 
viewastext archive="runthis.jar" mayscript> 

Note: Currently there is no mechanism in place to make use of the value returned by the 
20 Javacript method, so the Javascript call should be seen as a one-way call (which is suitable for 
most cases). 

Other Notes 

1. The Application Server environment manages the session life*. If a session expires 
25 and the Client is still active the user can be redirected to an HTML page (e.g. a Logon page) 
configured in the Server Configuration file. 
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2. The Sync Engine can be configuted to issue probe messages to the Client that let the 
Client know the Sync Engine is still live'. 

3. Parameters can be passed to Javascript 

5 

4. Use of Javascript may add additional compatibility issues. 
CHAPTER 5 - Logon Process 

10 Session Creation 

The Sync Engine requires access to the session on the Application server. Hence a session 
must be created before invoking the applet from the Host Page. The user logs on to the 
Application through its Logon process. This establishes a shared session on the Application 
server. 

15 

The Default Altio Login Process 

The Logon process used by the Altio Demonstration applications is described below and is 
also shown in Figure 17. The subsequent section gives examples and recommendations to 
help you code your own Logon mechanism. The Altio Logon HTML page creates a session 

20 by communicating to a Java servlet, which takes the parameters of user Name, Password, 
and the Application name as entered. Password and Application name are verified against 
the AltioLiveDemo.xml file. Once the correct parameters have been entered, a user session 
is created by the servlet so that user-specific data is displayed and the correct user 
preferences are used. There is also the option of loading different XML configuration files, 

25 which could depend on what is entered in the Application field as in the example, or some 
other parameters such as user type. 

The Altio Logon process is implemented as described below. 
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1. The user loads the logon HTML page in the browser, by typing the URL or 
following a link. 

2. The Logon page prompts the user to input user Name, Password and Application 
name. 

3. When user clicks *OK*, a communication link to the Logon Servlet is established. 

4. The Logon Servlet verifies the xiser Name, Password and Application name. 

5. If the logon information is correct, the Logon Servlet creates a Session Object with a 
unique Session ID. The Session ID is stored on the Application server with the 
session lifetime. The Logon Servlet also stores tiie parameters, ALJogon.name and 
ALJogon.config in the Session Object 

6. The name of tiie Client applet along with the Session ID (as a cookie) is passed to a 
Host HTML page. 

7. The Host HTML page tiien invokes the Client It sends the Session ID and the 
Logon request to the Sync Engine. 

8. The Sync Engine restores the Session Object with the Session ID. It retrieves the 
user Name and Application configuration file name firom the Session Object As a 
part of the Logon request, the user is then subscribed to the appropriate Datapools. 

9. The Client now sends an initialisation request to the Sync Engine accompanied by 
the Session ID. 

10. The Sync Engine requests Initial Data firom the Application database. 

11. The Sync Engine reads the Application configuration firom the Application 
configuration file. 

12. The Application configuration along witii user preferences and the Initial Data is 
sent to the Client in response to tiie initialization request 

13. After the initialization process, the Client sends the first Data Update request to the 
Sync Engine. The Data Updates are either streamed to or polled firom the Client If 
the streaming mechanism is used, tine streaming connection is opened in response to 
the first Data Update request and new data, if available, is sent to the Client If the 



wo 02/065286 



PCT/GB02/00578 



96 

polling mechanism is used, the first poll occurs after the logon and new data, if 
available, is sent to the Client. 

In the above process, the propagation of the Session ID at each stage is essential, since the 
5 Sync Engine can restore the session if it has received the Session ID. 

Independent Logon 

In your application you may have an existing Logon process or you may wish to write one. 
This logon mechanism must also create the session. You don*t need the AltioLiveDemo 
10 servlet and XML files once you log on through your own Logon handler. The Host page 
needs to be modified accordingly. If you would like an example HTML logon page and the 
Java servlet that it calls, please contact Altio Technical Support 

If no Logon process is required, then you can directly type the URL of the HTML page that 
calls a Java servlet. This servlet must perform the following tasks. 
15 • Creating a session with appropriate parameters 

• Passing the Client applet name along with the Session ID as the cookie to the Host 
HTML page 

When a session is created, the following tags need to be included: 

• logon.name - holds the user name 

20 • logon.conf - holds the name of the view configuration XML (client) 

• logon.app - holds the APPID as defined in the Sync Engine Admin tool. 

• Further tags specific to your application may also be included. 

This means that anyone with an internet connection could conceivably use your application. 
It also means you won't be able to track which users are using the application. 

25 A Technical Note detailing the No Login Handler is available firom Altio Tech Support 
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CLAIMS 

1. Client software, enabling a client device to run a network based application which 
uses structured data, in which the client software comprises: 

5 (a) a communications layer to send and receive messages over the 

network; 

(b) a database layer to store, and allow querying of, the structured data; 

(c) a rendering layer which generates, from the structured data in the 
database layer, data for a user interface; 

10 wherein the client software is self-contained to provide all of the communications, 

data storage/querying and rendering resources needed to run the network based 
application on the client device. 

2. The client software of Qaim 1 in which the database layer holds, independently of 
15 the structured data, configuration data which defines how that structured data can be 

interacted with from within the user interface. 

3. The client software of Claim 2 in which the rendering layer continuously combines 
sub-sets of the configuration data and the structured data at display time. 

20 

4. The client software of Claim 1 in which the database layer and rendering layer 
together provide an interactive, thick client interface for the client device such that 
sub-sets of the stmctured data held on the database layer can be selected, displayed, 
manipulated, altered or supplemented. 

25 

5. The client software of Claim 2 in which the structured data and the configuration 
data is set over a network from a presentation server. 
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6. The client software of Claim 1 which is generic in that it is configurable on demand 
to the configuration parameters applicable to a client device. 

7. The client software of Claim 6 in which the communications layer can use a broad 
5 range of different protocols and bearers, and the rendering layer can render to 

multiple device types. 

8. The client software of Claim 1 in which the structured data is in a self-describing 
meta-language, such as XML. 



10 



15 



9. The client software of Claim 1 in which one or more of the communications layer, 
database layer and rendering layer are plug-in components. 

10. The client software of Claim 1 which is implemented as a remotely deployable applet 

11. The client software of Claim 1 which can generate multiple windows in a browser 
window of the client device, with the data in each window obtained from the 
database layer. 



20 12. The client software of Claim 1 which allows different users to be able to see or 
manipulate different sub-sets of structured data relating to one or more network 
based applications and hence provides an access control mechanism. 

13. The client software of Claim 1 in which a change in the stmctured data held in the 
25 database layer leads the database layer to automatically communicate with the 

rendering layer, causing the rendering layer to update the user interface appropriately. 



14. 



The client software of Claim 1 in which a change in the user interface caused by user 
interaction causes the rendering layer to notify the database layer of the change. 
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15. The client software of Claim 14 in which a change to the database layer caused by 
the rendering layer can automatically cause ihe database layer to contact the 
communications layer and can cause it in turn to send messages over a network that 

5 indicate the chjinge. 

16. The client software of Claim 14 in which a change to the database layer caused by 
the rendering layer does not lead to the database layer contacting the 
communications layer so that the change is applied only locally at the client device. 

10 

17. The client software of Claim 1 which provides a zero-client footprint in that it is (a) 
installed on the client device only in response to die client device initiating or 
requesting a network based application and therefore does not need to be pre-loaded 
or installed and, (b) after tiie client device has ceased using tiie network based 

15 application, it is removed entirely from the client device. 

18. The client software of Claim 1 in which the database layer enables structured data 
from two or more different network based applications to be combined or 
manipulated in one or more windows running in a browser on the client device as 

20 though from a single network based application. 

19. The client software of Claim 1 which can generate multiple windows in a browser 
window of the client device, with a user able to sort data, edit data, or scroll tiirough 
data in each of tiie windows, without tiie need for tiiere to be any dient side software 

25 development. 



20. 



The client software of Claim 1 which allows XML structured data to be cut and 
pasted into a clipboard or other form of temporary memory. 
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21. The client software of Claim 1 which can generate multiple windows in a browser 
window of the client device, with any user able to dejSne a personalised arrangement 
of windows and data to be displayed in each window, with the data to be displayed in 
each window capable of being obtained from several different network based 

5 applications. 

22. The client software of Claim 1 in which structured data is associated with pre- 
defined controls by a developer and then at run time the client software 
automatically displays the data in conjunction with some or all of those controls. 

10 

23. The client software of Claim 1 in which the database layer can be accessed using 
XPath queries, in which standard XPath queries are enhanced with one or more of 
the following features: indexed retrieval; direct reference to elements and attributes 
identified by controls. 

15 

24. The client software of Claim 5 in which a session object allows the remote 
presentation server to provide to the database layer the applicable data and 
configuration parameters appropriate to the client device and the last state of the 
client device known to the remote presentation server. 

20 

25. A network based application which, when invoked or mn, causes client software as 
defined in any preceding Claims 1 - 24 to be run on a client device, 

26. A web server which hosts a network based application which requires client software 
25 as defined in any preceding Claims 1 - 24 to be run on a client device. 



27. 



A client device when programmed with client software as defined in any preceding 
Claims 1 - 24. 
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Figure 1 

Overview of the components of the ALC 
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Figure 2 

Initiate Client Communication 



Request web page containing ALC applet 



Initiate the ALC in Web Browser 



ALC calls Synchronisation Engine (SE) via default 
conununication protocol (HTTP). 



SE provides initial client configuration &, data 



ALC renders initial user display. 



ALC renegotiates communications 



ALC contacts server for data updates or refresh 



SE processes updates or provides re&eshed data 



ALC re- renders display 
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Figure 3 

User Requests Data 
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Figure 4 

AltioLive Client Configuration 
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Figure 6 

Synchronisation Engine Complex Configuration 
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Figure? 

The AltioLive Deployment Architecture 
Architecture 
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Figure 8 

The Synchronization Engine serves the initial data according to the information associated 
with the View (shown below). 




Figure 9 

An example Service Function, 
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Figure 10 

This screen view shows the datapool, which is used to get updates of items which the user 
has placed on tiieir watch list. 
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Figure 11 

A NEW SALE Service Function. 
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Figure 12 

A NEW_BID Service Function 
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Figure 13 

This element specifies the column of the "Select a product" list, including a GET_APPIMG 
image server command. 
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Figure 14 

The system architecture of an Altio Live application. 
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Figure 15 

The interaction between the Sync Engine and the Application. 
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Figure 16 

When using Altio Live in Dynannic mode it is necessary to change the HTML to reflect the 
connection to the Sync Engine. Figure 16 shows a typical example of this integration. 



Log-In page 



Host page 
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Figure 17 

The Logon process used by the Altio Demonstration applications. 





